NHibernate Invalid index N for this SqlParameterCollection with Count=N Exception 简易处理

Demo Mapping Config:

复制代码
 1   <class name="BaseTable" table="BaseTable">
 2     <id name="BaseId">
 3       <generator class="native"/>
 4     </id>
 5     <!--<discriminator column="SubType" type="String"/>-->
 6     <property name="Name" column="Name" type="String" />
 7     <property name="SubType" column="SubType" type="String" />
 8     <property name="BaseIrType" column="IrType" type="String"/>
 9     
10     <any name="SubObj" meta-type="string" id-type="Int32" cascade="all">
11       <meta-value value="People" class="Person"/>
12       <meta-value value="Company" class="Company"/>
13       <column name="SubType" />
14       <column name="SubId"/>
15     </any>
16   </class>
复制代码

 

当我插入数据的时候会报如下错误 :

 

当我在插入数据的时候会报如下错误 :

NHibernate: INSERT INTO People (FirstName, IrType) VALUES (@p0, @p1); select SCOPE_IDENTITY();@p0 = 'Cheng', @p1 = '0000AA'
TestCase 'NHDemo.Test.NHibernateSampleFixture.GetCustomerByIdTest'
failed: System.IndexOutOfRangeException : Invalid index 4 for this SqlParameterCollection with Count=4.
 at System.Data.SqlClient.SqlParameterCollection.RangeCheck(Int32 index)
 at System.Data.SqlClient.SqlParameterCollection.GetParameter(Int32 index)
 at System.Data.Common.DbParameterCollection.System.Collections.IList.get_Item(Int32 index)

 

此处异常显示: N = 4, 那就是配置文件的第4行有问题, 可以简单的先注释第4行做测试.

 

这里只启一个开头的作用, 具体的错误,根据自己的实际情况来解决.

posted @   DukeCheng  阅读(1362)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示