博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用NHibernate作为ORM容易碰到的问题
阅读量:6625 次
发布时间:2019-06-25

本文共 1389 字,大约阅读时间需要 4 分钟。

使用NHibernate作为ORM容易碰到的问题

1、Could not initialize proxy - no Session.

原因:hibernate3 many-to-one的默认选项是 lazy = "proxy"

解决方法:<many-to-one>  & <set> 中设置 lazy="false"

其实只在<many-to-one>中设置lazy="false"就可以了,在set也设置的话会多一次查询。

2、没有主键的表如何编写.hbm.xml配置文件

有.hbm.xml配置中都需要一个

1
2
3
<
id 
name
=
"ID"
>
     
<
generator 
class
=
"guid"
></
generator
>
</
id
>

没有<id>配置节的话会报错,但是有的表就是没有主键的。

比如说有的从表,例如订单明细表,在大部分情况下是不需要主键的。

其实没有<id>也可以,但是需要有<composite-id>,也就是联合主键。联合主键就是几个属性唯一标识当前记录。

换个思路了,把所有的属性加在一起作为联合主键。

1
2
3
4
5
<
composite-id
>
      
<
key-property 
name
=
"Amount"
></
key-property
>
      
<
key-property 
name
=
"CreateTime"
></
key-property
>
      
<
key-property 
name
=
"ModifyTime"
/>
    
</
composite-id
>

3、联合主键之后需要注意的地方

使用联合主键之后对应的Model需要实现Equals和GetHashCode方法,否则会报错。

1
2
3
4
5
6
7
8
9
10
public 
override 
bool 
Equals(
object 
obj)
     
{
         
var 
item = obj 
as 
CRMTypeCustomer;
         
return 
this
.CRMTypeID == item.CRMTypeID
             
&& 
this
.CustomerID == item.CustomerID;
     
}
     
public 
override 
int 
GetHashCode()
     
{
         
return 
base
.GetHashCode();
     
}

4、此SqlServerParameterCollection 的 Count=4 的索引 4 无效

原因是:

从表关联主表时的问题. 

1
<
many-to-one 
name
=
"dictate" 
column
=
"DICTATEID" 
class
=
"Model.JkptOaxtDictate,Model"
/>

修改为:

1
<
many-to-one 
name
=
"dictate" 
column
=
"DICTATEID" 
class
=
"Model.JkptOaxtDictate,Model" 
insert
=
"false" 
update
=
"false"
/>

即添加属性

1
insert="false" update="false"

本文转自 virusswb 51CTO博客,原文链接:http://blog.51cto.com/virusswb/1231140,如需转载请自行联系原作者

你可能感兴趣的文章
mysql 的mgr集群
查看>>
html5播放mp4视频代码
查看>>
032_nginx配置文件安全下载
查看>>
Linux下tomcat修改成的80端口无法访问
查看>>
Kubernetes 集群日志管理 - 每天5分钟玩转 Docker 容器技术(180)
查看>>
redis实现对账(集合比较)功能
查看>>
为了好好看球,学霸们用深度学习重建整个比赛3D全息图
查看>>
浅谈持续集成
查看>>
【ZH奶酪】如何用textgenrnn处理中文
查看>>
CentOS双机中Docker下安装Mysql并配置互为主从模式
查看>>
OkHttp3源码详解(六) Okhttp任务队列工作原理
查看>>
这样做,轻松在Word中使用MathType
查看>>
VS Code非英语版本连接TFS错误解决方案
查看>>
angular5中使用jsonp请求页面
查看>>
sql in not in 案例用 exists not exists 代替
查看>>
使用newtonjson解决Json日期格式问题
查看>>
WEB前端资源代码:学习篇
查看>>
Nginx安装及配置详解【转】
查看>>
vue2.0 :style :class样式设置
查看>>
测不准原理主要指向微观
查看>>