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

简介:

使用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,如需转载请自行联系原作者

目录
相关文章
|
7月前
|
缓存 Java 数据库连接
从ORM到实践:Hibernate与JPA的详细指南
【6月更文挑战第25天】ORM技术如Hibernate和JPA简化了Java与数据库交互。Hibernate是流行的ORM框架,JPA是Java EE的规范,两者结合提供了高效的数据持久化方案。配置Hibernate涉及数据库连接和实体映射。通过注解定义实体类,如`@Entity`、`@Table`、`@Id`等。持久化操作通过Session接口完成,例如保存对象。缓存、加载策略(延迟加载 vs. 立即加载)和查询优化是提升性能的关键。理解这些概念有助于选择和优化ORM使用。
174 0
|
SQL 关系型数据库 程序员
什么是ORM?为什么要使用ORM?底层原理是什么?
什么是ORM?为什么要使用ORM?底层原理是什么?
1457 0
|
SQL 算法 数据库
什么是ORM?为什么用ORM?浅析ORM的使用及利弊
什么是ORM ORM(Object-relational mapping),中文翻译为对象关系映射,是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据库中。
3195 0
|
SQL 安全 数据库
ORM映射框架总结--代码生成器
年前发布了一些文章,是关于.NET数据操作(点击查看)的。刚开始学习编程的时候,总感觉Java中的Hibernate 功能好强大,现在也不可否认它的确强大,特别是它在数据关系处理上,却是那样的让人称叹。
1273 0
|
XML SQL Java
Hibernate-ORM:14.Hibernate中的命名查询
      ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------         本篇博客讲述命名查询,所谓命名查询是什么呢? Hibernate中允许我们在xml,实体类,甚至注解的方式来编写查询语句,本篇博客将讲述xml中的方式 一,准备好准备工作,我由于上篇博客把大量的准备都做好,所以,本篇从简 二,预览hbm.
1060 0
|
Java 关系型数据库 数据库连接
Hibernate-ORM:11.Hibernate中的关联查询
      ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------         本篇博客将讲述Hibernate中的关联查询,及其级联(cascade)操作,以及指定哪一方维护关联关系的(inverse)   一,讲述目录如下:   1.
1241 0
|
SQL Java 数据库连接
Hibernate-ORM:07.Hibernate中的参数绑定
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------     本篇博客会讲解Hibernate中的参数绑定,就是相当于sql语句中的where后面的条件   一,讲解概述:   1.
1085 0
|
缓存 Java 数据库连接
Hibernate-ORM:06.Hibernate中三种状态
  ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------       本篇博客主要叙述Hibernate中的三种状态:临时状态(瞬时状态),持久状态,游离状态 commit和flush三种状态间的使用,commit和flush的区别: save...
1147 0
|
缓存 Java 数据库连接
Hibernate-ORM:04.Hibernate中的get()和load()
    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------       本篇博客会讲如何用get()或load()查询单个对象和对缓存的简单操作,以及他俩的区别和相同(前面有的那些配置不做重复展示,见谅)   Hibernate中查询单个,...
1196 0
|
SQL 关系型数据库 数据库
Hibernate-ORM:03.Hibernate主键生成策略
  ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------       此篇博客简单记录五种常用的主键生成策咯:   不同的主键生成策略,生成的sql语句,以及hibernate的操作都是不同的!   3.
1265 0