Lazy="false"反而出错

错误信息:

“System.Configuration.ConfigurationErrorsException”类型的异常在 Spring.Core.DLL 中发生,但未在用户代码中进行处理

其他信息: Error creating context '/hotelmis': Could not find the dialect in the configuration

从错误信息看到是配置文件出了问题,出现dialect的地方只有一个

<property
name="HibernateProperties">
     
<dictionary>
       
<entry key="hibernate.connection.provider"
value="NHibernate.Connection.DriverConnectionProvider"/>

<entry
key="hibernate.dialect"
value="NHibernate.Dialect.MsSql2000Dialect"/>
       
<entry key="hibernate.connection.driver_class"
value="NHibernate.Driver.SqlClientDriver"/>
       
<entry key="hibernate.show_sql"
value="true"/>
     
</dictionary>
   
</property>

这种写法是用在NHiberate12版本中的,如果在NHiberate21版本中应该改为:

<entry
key="dialect"
value="NHibernate.Dialect.MsSql2005Dialect"/>

错误信息:

命名空间“NHibernate”中不存在类型或命名空间名称“Expression”(是缺少程序集引用吗?)

命名空间出错:使用Criteria查询数据时用,NHiberate12是在NHibernate.Expression中,而NHiberate21是在NHibernate.Criterion中。

错误信息:

“Spring.Data.NHibernate.HibernateSystemException”类型的异常在
Spring.Data.NHibernate21.DLL 中发生,但未在用户代码中进行处理

其他信息: Invalid Cast (check your mapping for property type
mismatches); setter of DBLayer.MAP.Accredit.RoleFunction

这个错误光从字面上看是RoleFunction的映射文件中的内容跟类定义的属性不匹配引起的,实际上不是。是一对多关系中一方设置多方集合中的属性Lazy="false"引起的。因为使用了,所以Lazy="false"反而出错,其中具体是什么原因,本人没有深入的去了解。

<set name="RoleFunctions"
table="AC_Role_Function_Test" inverse="false" lazy="true"
cascade="all-delete-orphan">
     
<key column="RoleID" />
     
<one-to-many
class="DBLayer.MAP.Accredit.RoleFunction,DBLayer"
/>
   
</set>

Nhibernate 要求model实体类对于lazy="true" ,字段属性前需要加 virtual

sqlserver2005和oracle10g的hibernate.cfg.xml如何配置?
A:sqlserver2005配置如下
<!-- NHibernate sqlserver2005配置-->
<hibernate-configuration  xmlns="urn:nhibernate-configuration-2.2" >
  <session-factory name="db1">
    <!-- properties -->
    <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
    <property name="connection.driver_class">NHibernate.Driver.SqlClientDriver</property>
    <property name="dialect">NHibernate.Dialect.MsSql2005Dialect</property>
    <property name="connection.connection_string">
      Server=.;initial catalog=NhibernateTest;User Id=sa;Password=sa
    </property>
    <property name="use_outer_join">true</property>
    <property name="use_proxy_validator">true</property>
    <!--<property name="show_sql">false</property>-->
    <!--<property name="query.substitutions">true 1, false 0, yes 'Y', no 'N'</property>-->
    <!-- mapping files -->
    <mapping assembly="Kang.Model" />
  </session-factory>
</hibernate-configuration>

Oracle10g配置如下:
<!-- NHibernate Oracle10g配置-->
<hibernate-configuration  xmlns="urn:nhibernate-configuration-2.2" >
  <session-factory name="db1">
    <!-- properties -->
    <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
    <property name="connection.driver_class">NHibernate.Driver.OracleClientDriver&lt</property>
    <property name="dialect">NHibernate.Dialect.Oracle9Dialect&lt</property>
    <property name="connection.connection_string">
      data source=KANGSHI;User ID=huobj;Password=huobj
    </property>
    <property name="use_outer_join">true</property>
    <property name="use_proxy_validator">true</property>
    <!--<property name="show_sql">false</property>-->
    <!--<property name="query.substitutions">true 1, false 0, yes 'Y', no 'N'</property>-->
    <!-- mapping files -->
    <mapping assembly="Kang.Model" />
  </session-factory>
</hibernate-configuration>

Q:无法将类型为“NHibernate.Dialect.MsSqlCeDialect”的对象强制转换为类型“NHibernate.Driver.IDriver”。
A:当切换数据库时,相应的connection.driver_class属性是需要调整
  oracle10g是NHibernate.Driver.OracleClientDriver
  MsSql2005是NHibernate.Driver.SqlClientDriver

Q:could not execute query
A:总的原则是,Nhibernate查询还是遵守sql原规则的。
1 字段名称不对,
2 字段格式不对,注意日期、数字和字符
3&lt;property type="string" length="50" name="RoleName" column="[RoleName]" /&gt;
oracle必须把RoleName的[]去掉。而sqlsever去不用去[]都行。

Q:The type System.Int32 can not be assigned to a property of type
System.String setter of Kang.Model.Entities.USR_UserInfo.LoginID
A: 主键LoginID原定义的是int ,应该改成string

Q:Invalid Cast (check your mapping for property type mismatches); setter of Kang.Model.Entities.USR_UserInfo
A:length="80" 必须小于数据库表中字段的长度。另外,就是实体类中属性类的类型要和nhibernate-mapping 中的type同。

因为是在调用GetAll()方法是报的错,那我就一个属性一个属性的去掉,来调用这个方法,看究竟是哪个属性的类型不匹配。最终定位到一个枚举类型,在 实体类里定义该属性为枚举类型,但是在映射文件中使用的却是String类型,因此报错。因为枚举类型可以以String类型在数据库中存储,因此将实体 类中该类型改为String,编译运行,好了。

Q:数据库中的Date、DateTime和TimeStamp类型区别?
A:
DATETIME, DATE和TIMESTAMP类型是相关的。本文描述他们的特征,他们是如何类似的而又不同的。
DATETIME
类型用在你需要同时包含日期和时间信息的值时。MySQL检索并且以'YYYY-MM-DD
HH:MM:SS'格式显示DATETIME值,支持的范围是'1000-01-01 00:00:00'到'9999-12-31
23:59:59'。(“支持”意味着尽管更早的值可能工作,但不能保证他们可以。)
DATE类型用在你仅需要日期值时,没有时间部分。MySQL检索并且以'YYYY-MM-DD'格式显示DATE值,支持的范围是'1000-01-01'到'9999-12-31'。
TIMESTAMP列类型提供一种类型,你可以使用它自动地用当前的日期和时间标记INSERT或UPDATE的操作。如果你有多个TIMESTAMP列,只有第一个自动更新。

SqlDateTime 溢出。必须介于 1/1/1753 12:00:00 AM 和 12/31/9999 11:59:59 PM 之间。
滴答数必须介于 DateTime.MinValue.Ticks 和 DateTime.MaxValue.Ticks 之间。
参数名: ticks
A:实体类中这样定义就ok了  private DateTime _CreateDate = new DateTime(2009 - 9 - 9);

Q:有的哥们这么写,但是问题是麻烦。
             var whitelist = new[] { "UserId", "UserName", "UserParssord", "UserMail" };
                UpdateModel(user, whitelist);
                uService.UpdateUserInfo(user);
                return RedirectToAction("Index");
A:     可以这样写
               model = bll.GetModel(id);
                UpdateModel(model);
                bll.UpdateData(model);
                return RedirectToAction("Index")

父子表关联映射 ============================================== 
Q: 用户代码未处理 NHibernate.PropertyAccessException
  Message="Invalid Cast (check your mapping for property type mismatches); setter of Kang.Model.Entities.USR_UserInfo"
  Source="Kang.NHibernateHelper"
  A:<!--多对一关系:Users属于一个Role-->
 
<many-to-one name="RoleID" column="RoleID" not-null="true"
class="Kang.Model.Entities.RoleInfo" foreign-key="FK_RoleUsers" />

<!--一对多关系:Role有一个或多个Users-->
    <set name="Users" table="`USR_UserInfo`" generic="true" inverse="true">
      <key column="RoleInfo" foreign-key="FK_RoleUsers"/>
      <one-to-many class="Kang.Model.Entities.USR_UserInfo"/>
    </set>
 
 Q:Duplicate property mapping of RoleID found in Kang.Model.Entities.USR_UserInfo
 A:有重复的属性定义。属性对象化,页面调用显示时可以再调用属性的属性,如:model.RoleID.RoleName

Q:Could not initialize proxy - the owning Session is disconnected
 A:对于父子关联表,把lazy="false"

hibernate 出错 集合的更多相关文章

  1. Hibernate的集合映射与sort、order-by属性

    [Hibernate]Hibernate的集合映射与sort.order-by属性 常用集合Set.List.Map,相信大家都很熟悉,面试中也会经常问.Set和List都继承了Collection接 ...

  2. Hibernate的集合映射(Set、List、Array、Map、Bag)

    POJOs如下: Customer类------>customer表   Order类对应---------->orders表  customer(1)<-------------- ...

  3. hibernate学习系列-----(9)hibernate对集合属性的操作之Map集合篇

    照旧,先新建一个StudentMap.java实体类,将hobby属性使用map集合接口来存放: package com.joe.entity; import java.util.Map; publi ...

  4. hibernate学习系列-----(8)hibernate对集合属性的操作之Collectioon集合篇

    度过短暂的周末,又到了周一,继续轻松而愉快的学习,紧承以前的学习,继续了解hibernate对集合的操作学习之旅! 在上一篇中,就已经提前说过,这一篇的内容以及下一篇的内容会有很多相似之处,这里就不再 ...

  5. hibernate学习系列-----(7)hibernate对集合属性的操作之List集合篇

    今天要写的内容其实不多,本打算将hibernate对集合的操作的内容直接归结为一篇的,但想一想,还是分开写的比较好,毕竟前面的已经发布出去来了,废话不多说,开始吧! 依旧新建一个StudentList ...

  6. Hibernate映射集合属性

    Hibernate要求持久化集合属性字段必须声明为接口,实际的接口可以是java.util.Set,java.util.Collection,java.util.List,java.util.Map, ...

  7. 1-6 hibernate映射集合属性

    1.集合类框架 以Tree开头都是按顺序,默认情况下是升序排列. 以Linked 开头的都是按插入顺序排列的. 2.在hibernate中要持久化集合属性时必须将其声明为接口,如 private Se ...

  8. Hibernate之集合映射的使用(Set集合映射,list集合映射,Map集合映射)

    a:数据库的相关知识: (1):一个表能否有多个主键:不能: (2):为什么要设置主键:数据库存储的数据都是有效的,必须保持唯一性: (3)为什么id作为主键:因为表中通常找不到合适的列作为唯一列,即 ...

  9. Hibernate的集合一对多与多对一

    需求:   部门与员工 一个部门有多个员工;       [一对多] 多个员工,属于一个部门    [多对一] 1.javaBean ——Dept.java package com.gqx.oneto ...

随机推荐

  1. 查询MySQL的存储引擎

  2. 浅谈前端性能优化(二)——对HTTP传输进行压缩

    1.前端性能优化的一点: 对js.css.图片等进行压缩,尽可能减小文件的大小,减少文件下载的时间,从而减少网页响应的时间. 2.前端性能优化的另一点: 对HTTP传输进行压缩,即在js,css.图片 ...

  3. NFS服务器实现文件共享

    NFS服务器运行原理 实战配置NFS服务器 配置Samba服务器及实现文件共享 (一)NFS器服务端描述 NFS服务器: Network File System,网络文件系统使FreeBSD支持的一种 ...

  4. 2018.10.03 NOIP+ 模拟赛 解题报告

    得分: \(30+5+0=35\)(考得真不咋滴) \(T1\):奥义商店(点此看题面) 以为很简单,对着这题想了一个多小时,最后果断打了个暴力交了... ... 看完题解发现其实也不是很难. 对于\ ...

  5. 2018.5.18 AndroidStudio创建项目出错

    Android Studio 出现 Gradle's dependency cache may be corrupt 错误分析 Error:Failed to open zip file. Gradl ...

  6. RxJava2 方法总结

    RxJava2 方法总结 看了许多讲解RxJava的文章,有些文章讲解的内容是基于第一个版本的,有些文章的讲解是通过比较常用的一些API和基础的概念进行讲解的. 但是每次看到RxJava的类中的几十个 ...

  7. CUDA:Supercomputing for the Masses (用于大量数据的超级计算)-第七节

    第七节:使用下一代CUDA硬件,快乐加速度 原文链接 Rob Farber 是西北太平洋国家实验室(Pacific Northwest National Laboratory)的高级科研人员.他在多个 ...

  8. 二、MySQL 管理

    MySQL 管理 启动及关闭 MySQL 服务器 Windows 系统下 在 Windows 系统下,打开命令窗口(cmd),进入 MySQL 安装目录的 bin 目录. 启动: cd c:/mysq ...

  9. Linux 系统性能:观察、测试、调优

    一个完整运行的 Linux 系统包括很多子系统(介绍,CPU,Memory,IO,Network,…),监测和评估这些子系统是性能监测的一部分.我们往往需要宏观的看整个系统状态,也需要微观的看每个子系 ...

  10. 三 python并发编程之多线程-理论

    一 什么是线程 在传统操作系统中,每个进程有一个地址空间,而且默认就有一个控制线程 线程顾名思义,就是一条流水线工作的过程,一条流水线必须属于一个车间,一个车间的工作过程是一个进程 车间负责把资源整合 ...