1.Hibernate3.1+MySQL5.0数据持久化时异常:
异常1:
Could not execute JDBC batch update
异常2:
could not load an entity
解决办法:原来使用MySQL的3.1.13的驱动,现在更换为5.0的驱动,问题解决,同时注意将项目中的3.1.13的驱动删除,以及部署目录中的3.1.13的驱动删除。
2.
Hibernate中Session的合理关闭时机:
一直没有找到好的解决方法,暂时在过滤器中每次请求更换时关闭。
3.解决
a different object with the same identifier value was already associated with the session错误
实际上在Hibernate中对数据的更新,应该先查询出该记录,然后修改该记录,最后使用Session更新该记录。
或者解决的办法是使用Hibernate里面自带的merge()方法,这种错误经常出现在一对多映射和多对多映射.
4.
Data truncation: Data too long for column ‘column_name’ at row 1
解决办法,如果数据库和数据库连接串指定的编码不同,出了会出现乱码,有时候还会出现很多奇怪的事,建立数据库时:create database cms default charset gb2312;
5.
Set与Map的排序
在查询对象的Set或Map成员时,您可以对其进行排序,排序可以在两个层次进行,一个是在Java执行环境中进行,一个是利用数据库本身的排序功能。
如果要在Java执行环境中进行排序,可以映像文件中设定sort属性,例如若为Set,则如下设定:
<set name="addrs" table="ADDRS" sort="natural">
<key column="USER_ID"/>
<element type="string" column="ADDRESS" not-null="true"/>
</set>
藉由指定sort为natural,Hibernate在加载数据库的数据时,将使用java.util.SortedSet型态对象,如果是String,则根据compareTo()方法来进行排序,上面的设定将会根据FILENAME进行排序。
如果是Map的话,则如下设定:
<map name="files" table="FILES" sort="natural">
<key column="USER_ID"/>
<index column="DESCRIPTION" type="string"/>
<element type="string" column="FILENAME" not-null="true"/>
</map>
上面的设定将使用java.util.SortedTree,根据DESCRIPTION进行排序,sort除了设定natural之外,也可以指定一个实现java.util.Comparator的类别名称。
以上的说明都是在查询数据时使用,User类别的属性成员撰写时可以是Map或Set型态,注意当设定sort="natural",并想要进行数据储存时,User类别的属性成员也必须更改为SortedMap或SortedSet型态,例如java.util.TreeMap或 java.util.TreeSet,否则会发生ClassCastException。
如果是利用数据库本身的排序功能,则使用order-by设定排序的方式,Hibernate会使用SQL语句在数据库中进行排序,例如在Set中是这么设定的:
<set name="addrs" table="ADDRS" order-by="ADDRESS desc">
<key column="USER_ID"/>
<element type="string" column="ADDRESS" not-null="true"/>
</set>
注意order-by中填写的是数据库表中的字段名称。
在Map中也是相同的设定方式,您也可以利用数据库中的函式功能,例如:
<map name="files" table="FILES" order-by="lower(FILENAME)">
<key column="USER_ID"/>
<index column="DESCRIPTION" type="string"/>
<element type="string" column="FILENAME" not-null="true"/>
</map>
使用这个方法进行排序时,Hibernate会使用LinkedHashSet或LinkedHashMap实现查询时的排序,所以这个方法仅适用于JDK 1.4或以上的版本
分享到:
相关推荐
本书适合作为Java/Java EE开发的初、中级读者的参考书,也可作为需要掌握Struts、Hibernate和Spring开源框架技术或学习其整合的读者使用,也非常适合高校相关专业的学生、社会Java技术培训班作教材使用。...
本书分为6大部分,共33章,介绍了Struts1框架、Hibernate框架、Spring框架和Struts2框架的开发环境配置、框架技术基础,Struts1框架和Spring框架的整合,Struts1框架和Hibernate框架的整合,Struts1框架、Hibernate...
本书适合作为Java/Java EE开发的初、中级读者的参考书,也可作为需要掌握Struts、Hibernate和Spring开源框架技术或学习其整合的读者使用,也非常适合高校相关专业的学生、社会Java技术培训班作教材使用。...
在线考试系统采用Struts+hibernate+mysql等技术开发,验证采用javascript为主,少量配合使用struts,ActionForm验证。通过项目开发加深对所学知识的理解、熟悉项目开发流程及管理制度,提高技术水平并为今后工作...
本书适合作为Java/Java EE开发的初、中级读者的参考书,也可作为需要掌握Struts、Hibernate和Spring开源框架技术或学习其整合的读者使用,也非常适合高校相关专业的学生、社会Java技术培训班作教材使用。...
包含JDBC基础教程 JSP基础,jsp图片验证 Servlet spring入门,hibernate入门,struts入门, 两年技术积累的帮助文档,手工整理,涵盖主流开发框架,吐血奉献
Hibernate 到 Spring、Ajax 的主流开发技术,适合于从事 Web 应用开发的初、中级程序员使 用。通过对本书的学习,读者可以掌握 J2EE Web 开发技术,同时经过对本书中实例的实战 演练,能够积累大量实际开发的经验与技巧...
本人在从事java项目开发过程中的笔记,积累了一些经常google的知识,希望对大家有所借鉴
" " "2、JSP、JavaBean、Servlet、JDBC、Struts、Hibernate、Spring" " "、EJB、 Web Service、JMS、JTA、JTS技术开发; " " "3、系统集成、优化。 " "数据库应用 "考核要点 "分值 "20 " "数据库应用 "1、数据库...
ExmayCMS采用Struts2 Spring Hibernate Lucene3 EhCache Freemarker JQuery等主流技术架构,默认使用MySQL数据库,并支持Oracle、SqlServer、Sybase、DB2等主流数据库,全部源代码永久开放,无任何功能限制。...
之后 等你对Java EE有些感悟的时候,你自然就会想不断扩展你的知识面,这时候你可以学习Spring、Hibernate,以及各种Web框架(如Struts、JSF、Webwork或是Tapestry等)。 随着技术、经验的不断积累,你会逐步关注分析...
目前, J2EE 应用确实很流行,从银行、证券...2EE 的图书,居然在 JSP 页面中有 Hibernate 的 API 。于是我无言以对,这样的图书到 底想使读者成为怎样的开发者?阅读这样的图书不仅浪费时间,而且会造成错误的积累。
目前, J2EE 应用确实很流行,从银行、证券...2EE 的图书,居然在 JSP 页面中有 Hibernate 的 API 。于是我无言以对,这样的图书到 底想使读者成为怎样的开发者?阅读这样的图书不仅浪费时间,而且会造成错误的积累。
平时工作积累封装的一些工具类,包括hibernate底层封装,字符串,日期的转换,缓存,分页,email,tree,log,json,gson,struts2,spring,io等一些常用的工具类,足够满足日常开发了,能帮助开发者提高一些效率.....
ExmayCMS采用Struts2 Spring Hibernate Lucene3 EhCache Freemarker JQuery等主流技术架构,默认使用MySQL数据库,并支持Oracle、SqlServer、Sybase、DB2等主流数据库,全部源代码永久开放,无任何功能限制。...
把以前自己的小项目加入Struts、Spring、Hibernate的元素吧。 去研究各种商业项目的业务逻辑吧,才能在你的简历中加入浓重的一笔。 EJB3.0,java在走了很多弯路后的回归之作,值得研究。 SOA,业界铁定的未来...