Hibernate学习
1. 入门实例 - "+document.title
这篇文章主要谈谈Hibernate的入门开发,例子很简单,就是向数据表中添加用户名和密码。我分别使用了三种方法,一种是直接写代码,写Hbm映射文件等;一种是通过Hbm映射文件来生成代码;一种是通过代码来生成Hbm映射文件。使用了一些自动化工具,XMLBuddy是用来编辑XML文件的,JBossEclipseIDE是用来编写Doclet标记的。这篇文章还谈到了一些Eclipse的使用技巧,比如建立“用户库”、“生成Getter和Setter”等。
关于一些软件的使用技巧,我以前的文章都有提及,这里不多说了,必要时会提示一下。
一、下载、安装和配置
1.所需软件
●Ant1.6.2http://ant.apache.org
下载http://mirror.apache.or.kr/ant/binaries/apache-ant-1.6.2-bin.zip
● Eclipse 3.0.1 及 语言包
参考: http://blog.csdn.net/javamxj/archive/2004/10/11/131952.aspx
● XDoclet 1.2.2 http://xdoclet.sourceforge.net/xdoclet/
下载http://prdownloads.sourceforge.net/xdoclet/xdoclet-bin-1.2.2.zip?download
● XMLBuddy http://www.xmlbuddy.com/ 下载 XMLBuddy 2.0.38
●JBossEclipseIDEhttp://www.jboss.org/products/jbosside
看看说明,需要挑选与使用的eclipse相对应的版本,这里选择JBossIDE-1.4.1-e30.zip,这是它的镜像下载地址:
http://prdownloads.sourceforge.net/jboss/JBossIDE-1.4.1-e30.zip?download
●Hibernatehttp://www.hibernate.org/
下载Hibernate2.1.8
http://prdownloads.sourceforge.net/hibernate/hibernate-2.1.8.zip?download
同时也要把HibernateExtensions2.1.3下载了,它包含一些工具类。
下载http://prdownloads.sourceforge.net/hibernate/hibernate-extensions-2.1.3.zip?download
●MySQL4.1.8
参考:http://blog.csdn.net/javamxj/archive/2005/01/13/251861.aspx
注意需要mysql-connector-java-3.0.16-ga-bin.jar文件
2. 安装和配置
这里着重指出一下,需要在环境变量中设置ANT_HOME,并将其指向Ant安装目录,还要在Path变量值中添加“%ANT_HOME%\bin;”可以参考java环境变量设置。
· XMLBuddy 和Jboss-ide 我都是采用links方式安装的,参考 http://blog.csdn.net/javamxj/archive/2004/10/11/132311.aspx
●建立库文件夹:
在D盘下新建一个java目录,在此目录下新建一个Hibernate子目录,在此子目录下再新建一个lib子目录。
D:\
-java
-Hibernate
-lib
·将下载的hibernate-2.1.8.zip解压,如解压后的目录名为hibernate-2.1,将这个目录下的hibernate2.jar复制到先前建立的lib目录下,即D:\java\Hibernate\lib目录;
·然后将hibernate-2.1目录下的lib子目录中的以下文件也复制到这个lib目录下:
jta.jarcglib-full-2.0.2.jarcommons-collections-2.1.1.jarcommons-logging-1.0.4.jarcommons-lang-1.0.1.jardom4j-1.4.jarehcache-0.9.jarlog4j-1.2.8.jarodmg-3.0.jarodmg-3.0.jar
·解压hibernate-extensions-2.1.3.zip,将其子目录tools中的hibernate-tools.jar和子目录lib中的velocity-1.3.1.jar、jdom.jar也复制到D:\java\Hibernate\lib目录中
·解压xdoclet-bin-1.2.2.zip,将其子目录lib中的xdoclet-1.2.2.jar、xdoclet-hibernate-module-1.2.2.jar、xjavadoc-1.1.jar、xdoclet-xdoclet-module-1.2.2.jar也复制到D:\java\Hibernate\lib目录中
·最后将mysql-connector-java-3.0.16-ga-bin.jar文件复制到这个lib目录下。
这样,需要用到的库文件已经准备好了,如果认为这样比较麻烦,也可以将jar文件全部复制到lib目录。下面介绍如何在Eclipse中设置“用户库”。
●设置“用户库”
·窗口->首选项->Java->构建路径->用户库,
·然后单击“添加JAR”
这样,一个用户库文件就做好了,如果要更新Eclipse时,可以将其先导出,然后再导入即可。
这样做,对库文件便于管理,而且如果需要替换或者升级的话都比较方便。
●设置“构建路径”
· 点击菜单“窗口”->首选项,以下都在“首选项”中配置:Java->构建路径
二、项目实践
这里以一个简单的程序来示范Hibernate的配置与功能,在这个例子中的一些操作,实际上会使用一些自动化工具来完成,而不一定亲自手动操作设定,这边完全手动的原因,在于让你可以知道Hibernate的基本流程。
这是整个项目的结构:
好了,下面就开始创建项目了。
1.创建项目
·新建一个Java项目:HibernateBegin_1,注意选中“创建单独的源文件夹和输出文件夹”。点击“下一步”,切换到“库”,点击“添加库”,如下图:
·选择“用户库”
·勾选先前设置好的hibernate用户库。
2.建立可持久化类
· 下面开始创建一个新类:User ;包名:javamxj.hibernate ;然后添加三个变量(斜体),代码如下:
/*
*采用常规方法开发一个简单的Hibernate实例
*创建日期2005-3-31
*@authorjavamxj(分享java快乐)
*@linkBlog:htpp://javamxj.mblogger.cn
*htpp://blog.csdn.net/javamxj/
*/package javamxj.hibernate;
public class User {
privateintid;
privateStringusername;
private String password;}
·点击工具栏上的“源代码(S)”,选择其中的“生成Getter和Setter”(右击,在弹出菜单也可选择),如图:
点击“确定”后,生成如下代码:
/*
*采用常规方法开发一个简单的Hibernate实例
*创建日期2005-3-31
*@authorjavamxj(分享java快乐)
*@linkBlog:htpp://javamxj.mblogger.cn
*htpp://blog.csdn.net/javamxj/
*/package javamxj.hibernate;
public class User {
privateintid;
privateStringusername;
private String password;public int getId() {
returnid;
}
publicvoidsetId(intid){
this.id=id;
}
publicStringgetPassword(){
returnpassword;
}
publicvoidsetPassword(Stringpassword){
this.password=password;
}
publicStringgetUsername(){
returnusername;
}
publicvoidsetUsername(Stringusername){
this.username=username;
}
}
好了,这个类完成了。它是一个普通的Java对象(PlainOldJavaObjects,就是POJOs,有时候也称作PlainOrdinaryJavaObjects),表示一个数据集合。下面建立一个Hbm文件将这个类映射到数据库的表格上。
3.映射文件
在javamxj.hibernate包下,新建一个名称为“User.hbm.xml”的文件,使用XMLBuddy编辑它(参考:利用XMLBuddy在Eclipse中开发XML),这样比较方便。文件内容如下:
<?xmlversion="1.0"encoding="GBK"?>
<!DOCTYPEhibernate-mapping
PUBLIC"-//Hibernate/HibernateMappingDTD//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">
<hibernate-mapping><class name="javamxj.hibernate.User" table="UserTable">
<idname="id">
<generatorclass="assigned"/>
</id>
<propertyname="username"/>
<propertyname="password"/>
</class></hibernate-mapping>
这个XML文件定义了对象属性映射到数据库表的关系,这里采用了assigned(程序设置)方式生成主键。当然还可以使用其它的方式来产生主键,后面的文章就采用了其它的方式产生主键。
<property>标签用于定义Java对象的属性,这里只定义了最简单的方式,由Hibernate自动判断Java对象属性与数据库表名称对应关系。在<property/>标签上的额外设定(像是notnull、sql-type等),则可以用于自动产生Java对象与数据库表的工具上。
4. 配置文件
Hibernate可以使用XML或属性文件来进行配置,配置文件名默认为“hibernate.cfg.xml”(或者hibernate.properties)。
在src目录下,新建一个hibernate.cfg.xml文件,内容如下:
<?xmlversion='1.0'encoding='GBK'?>
<!DOCTYPEhibernate-configuration
PUBLIC"-//Hibernate/HibernateConfigurationDTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd"><hibernate-configuration>
<session-factory>
<!-- 是否将运行期生成的SQL输出到日志以供调试 -->
<propertyname="show_sql">true</property>
<!--SQL方言,这里设定的是MySQL-->
<propertyname="dialect">net.sf.hibernate.dialect.MySQLDialect</property>
<!--JDBC驱动程序-->
<propertyname="connection.driver_class">com.mysql.jdbc.Driver</property>
<!--JDBCURL,"?useUnicode=true&characterEncoding=GBK"表示使用GBK进行编码-->
<propertyname="connection.url">
jdbc:mysql://localhost:3306/HibernateTest?useUnicode=true&characterEncoding=GBK
</property>
<!--数据库用户名-->
<propertyname="connection.username">root</property>
<!--数据库密码-->
<property name="connection.password">javamxj</property><!-- 指定User的映射文件 --> <mapping resource="javamxj/hibernate/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
注意:这里使用的是“jdbc:mysql://localhost:3306/HibernateTest?useUnicod...”中的HibernateTest数据库,你需要在MySql中建立这个数据库。
5.测试程序
在javamxj.hibernate包下,新建一个Test类,内容如下:
/*
*简单测试一下User类
*创建日期2005-3-31
*@authorjavamxj(分享java快乐)
*/
package javamxj.hibernate;import net.sf.hibernate.*;import net.sf.hibernate.cfg.*;
public class Test {
public static void main(String[] args) {
try {
SessionFactorysf=newConfiguration().configure()
.buildSessionFactory();
Sessionsession=sf.openSession();
Transaction tx = session.beginTransaction();User user = new User();
user.setUsername("Blog");
user.setPassword("分享java快乐");session.save(user);
tx.commit();
session.close();} catch (HibernateException e) {
e.printStackTrace();
}
}
}
这里简单说说一下流程,首先初始化Configuration,加载Hibernate的配置信息,然后Configuration取得SessionFactory对象,并由它来开启一个Session,它代表对象与表格的一次会话操作,而Transaction则表示一组会话操作,我们只需要直接操作User对象,并进行Session与Transaction的相关操作,Hibernate就会自动完成对数据库的操作。
6.配置数据库
在运行测试程序之前,还必须先设置好数据库。
在MySQL中建立一个HibernateTest数据库,并建立UserTable表,SQL语句如下:
CREATETABLEusertable(
IDint(6)NOTNULLauto_increment,
usernamevarchar(24)NOTNULLdefault'',
passwordvarchar(24)NOTNULLdefault'',
PRIMARYKEY(ID)
);
这里,HibernateTest与hibernate.cfg.xml配置文件中的HibernateTest相对应,UserTable与hbm映射文件中的UserTable相对应。
7.运行程序
右击Test.java,点击运行,可以看到控制台输出一系列信息,最后一条输出语句应该是:
Hibernate:insertintoUserTable(username,password,id)values(?,?,?)
在下篇文章中会介绍如何利用log4j来控制输出信息。
同时,在数据库中可以看到,数据已经添加进表里了:
小结:
Hibernate原理方面我不想多说,实际上知道也不多,况且这方面的资料很多,比如Hibernate本身自带的中文文档、夏昕编写的《Hibernate开发指南》、良葛格编写的“Hibernate入门”等都是非常不错的,现在关于Hibetnate的书籍也多了起来。
我所作的工作就是要使新手能尽快上手Hibernate,理论方面我不想过多纠缠,尽量以实例说话。我想,与其凭空说一个技术多好多好,倒不如给我一个可以上手的实例操作一下。好了,不多说废话了。
小结:
Hibernate原理方面我不想多说,实际上知道也不多,况且这方面的资料很多,比如Hibernate本身自带的中文文档、夏昕编写的《Hibernate开发指南》、良葛格编写的“Hibernate入门”等都是非常不错的,现在关于Hibetnate的书籍也多了起来。
我所作的工作就是要使新手能尽快上手Hibernate,理论方面我不想过多纠缠,尽量以实例说话。我想,与其凭空说一个技术多好多好,倒不如给我一个可以上手的实例操作一下。好了,不多说废话了。
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=335076
<src="http://writeblog.csdn.net/PromoteIcon.aspx?Id=335076"type="text/javascript">[点击此处收藏本文]发表于2005年04月02日15:26:00
< type="text/javascript">function hide(){showComment();} < type="text/javascript">document.write("");
javamxj 发表于2005-04-04 2:40 PM IP:
TrackBack来自《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发》:
Ping Back来自:blog.csdn.net
javamxj 发表于2005-04-05 4:47 PM IP:
TrackBack来自《Eclipse快速上手Hibernate--3. 利用XDoclet开发 》:
Ping Back来自:blog.csdn.net
javamxj 发表于2005-04-11 12:22 AM IP:
TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1)》:
Ping Back来自:blog.csdn.net
javamxj 发表于2005-04-11 12:22 AM IP:
TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1)》:
Ping Back来自:blog.csdn.net
javamxj 发表于2005-04-13 12:03 AM IP:
TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(3) 》:
Ping Back来自:blog.csdn.net
esmiles 发表于2005-04-14 12:27 PM IP: 210.83.200.*
问一下,设置“构建路径”有什么用处?谢谢
javamxj 发表于2005-04-14 1:40 PM IP: 218.79.116.*
Toesmiles:
设置“构建路径”是为了与后面文章中的build.xml相配合
super2 发表于2005-05-02 4:24 PM IP: 61.167.132.*
(cfg.Environment483)Hibernate2.1.8
(cfg.Environment512)hibernate.propertiesnotfound
(cfg.Environment543)usingCGLIBreflectionoptimizer
(cfg.Environment572)usingJDK1.4java.sql.Timestamphandling
(cfg.Configuration909)configuringfromresource:/hibernate.cfg.xml
(cfg.Configuration881)Configurationresource:/hibernate.cfg.xml
(cfg.Configuration332)Mappingresource:xzl/hibernate/user.hbm.xml
(cfg.Binder229)Mappingclass:xzl.hibernate.User->usertable
(cfg.Configuration1067)ConfiguredSessionFactory:null
(cfg.Configuration641)processingone-to-manyassociationmappings
(cfg.Configuration650)processingone-to-oneassociationpropertyreferences
(cfg.Configuration675)processingforeignkeyconstraints
(dialect.Dialect86)Usingdialect:net.sf.hibernate.dialect.MySQLDialect
(cfg.SettingsFactory70)Maximimouterjoinfetchdepth:2
(cfg.SettingsFactory74)Useouterjoinfetching:true
(connection.DriverManagerConnectionProvider42)UsingHibernatebuilt-inconnectionpool(notforproductionuse!)
(connection.DriverManagerConnectionProvider 43 ) Hibernate connection pool size: 20Exception in thread "main" java.lang.NoClassDefFoundError: org/aspectj/lang/Signature
atjava.lang.Class.forName0(NativeMethod)
atjava.lang.Class.forName(Class.java:164)
atnet.sf.hibernate.connection.DriverManagerConnectionProvider.configure(DriverManagerConnectionProvider.java:55)
atnet.sf.hibernate.connection.ConnectionProviderFactory.newConnectionProvider(ConnectionProviderFactory.java:83)
atnet.sf.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:76)
atnet.sf.hibernate.cfg.Configuration.buildSettings(Configuration.java:1172)
atnet.sf.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:803)
atxzl.hibernate.Test.main(Test.java:22)
请问这是什么问题呀?谢谢
阿义 发表于2005-05-03 2:45 AM IP: 218.2.173.*
可能是因为你生成的hibernate.cfg.xml文件里面数据库密码错误
阿义 发表于2005-05-03 5:11 AM IP: 218.2.173.*
你把build.xml里mysql用户名密码改成自己的就应该没有问题了~
jason 发表于2005-05-17 11:21 AM IP: 211.100.227.*
log4j:WARNNoappenderscouldbefoundforlogger(net.sf.hibernate.cfg.Environment).
log4j:WARNPleaseinitializethelog4jsystemproperly.
Hibernate:insertintousertable(username,password,id)values(?,?,?)
Exceptioninthread"main"java.lang.StringIndexOutOfBoundsException:Stringindexoutofrange:10
atjava.lang.String.charAt(String.java:558)
atcom.mysql.jdbc.StringUtils.escapeSJISByteStream(StringUtils.java:280)
atcom.mysql.jdbc.StringUtils.getBytes(StringUtils.java:105)
atcom.mysql.jdbc.PreparedStatement.setString(PreparedStatement.java:1068)
atnet.sf.hibernate.type.StringType.set(StringType.java:26)
atnet.sf.hibernate.type.NullableType.nullSafeSet(NullableType.java:48)
atnet.sf.hibernate.type.NullableType.nullSafeSet(NullableType.java:35)
atnet.sf.hibernate.persister.EntityPersister.dehydrate(EntityPersister.java:389)
atnet.sf.hibernate.persister.EntityPersister.insert(EntityPersister.java:462)
atnet.sf.hibernate.persister.EntityPersister.insert(EntityPersister.java:438)
atnet.sf.hibernate.impl.ScheduledInsertion.execute(ScheduledInsertion.java:37)
atnet.sf.hibernate.impl.SessionImpl.executeAll(SessionImpl.java:2438)
atnet.sf.hibernate.impl.SessionImpl.execute(SessionImpl.java:2391)
atnet.sf.hibernate.impl.SessionImpl.flush(SessionImpl.java:2260)
atnet.sf.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:61)
at javamxj.hibernate.Test.main(Test.java:26)
jason 发表于2005-05-17 11:23 AM IP: 211.100.227.*
上面是什么原因导致的?
qinfe 发表于2005-05-17 3:38 PM IP: 210.75.0.*
你好!
我在做的時候怎么出現hibernate.cfg.xml文件沒有被找到,并且拋出異常:
Exceptioncontent:net.sf.hibernate.HibernateException:/hibernate.cfg.xmlnotfound
net.sf.hibernate.HibernateException:/hibernate.cfg.xmlnotfound
atnet.sf.hibernate.cfg.Configuration.getConfigurationInputStream(Configuration.java:886)
atnet.sf.hibernate.cfg.Configuration.configure(Configuration.java:910)
atnet.sf.hibernate.cfg.Configuration.configure(Configuration.java:897)
at javamxj.hibernate.Test.main(Test.java:8)
javamxj 发表于2005-05-17 5:08 PM IP: 218.79.116.*
Toqinfen:
没有更多的信息,我也不清楚你的错误原因,hibernate.cfg.xml应该在javamxj.hibernate包下。
cym 发表于2005-06-12 3:45 PM IP: 61.186.252.*
文笔和功力都相当不错,难得的市写的清晰易懂,全部收藏,downloading..........感谢作者的无私奉献
cym 发表于2005-06-12 3:49 PM IP: 61.186.252.*
不过开发hibenate的话,myeclipse的用法更简单直接。我学习ejb,可是通过你的大作,参考并获得成功。谢谢
zesila_80 发表于2005-06-22 9:30 AM IP:
TrackBack来自《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发(摘自javamxj的blog)》:
Ping Back来自:blog.csdn.net
zesila_80 发表于2005-06-22 9:34 AM IP:
TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1)(摘自javamxj的blog)》:
Ping Back来自:blog.csdn.net
zesila_80 发表于2005-06-22 9:37 AM IP:
TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(3)(摘自javamxj的blog)》:
Ping Back来自:blog.csdn.net
Anne 发表于2005-06-23 10:43 PM IP: 61.186.252.*
你好:
你的解說真的很詳盡,可我在實作的過程中發生了兩個錯誤:
一是MySql一直不能啟動,不論我參考網上的任何解決方式,都沒法解決,所以我只好改用oracle當資料庫!!
二是我在執行過程中,發生了和上面qinfen同樣的問題,我也確認我的hibernate.cfg.xml在javamxj.hibernate包下,可是還是發生了這個錯誤訊息,請問你有解決之道嗎?
ErrorMessage:
(cfg.Environment483)Hibernate2.1.8
(cfg.Environment512)hibernate.propertiesnotfound
(cfg.Environment543)usingCGLIBreflectionoptimizer
(cfg.Environment572)usingJDK1.4java.sql.Timestamphandling
(cfg.Configuration909)configuringfromresource:/hibernate.cfg.xml
(cfg.Configuration881)Configurationresource:/hibernate.cfg.xml
(cfg.Configuration885)/hibernate.cfg.xmlnotfound
net.sf.hibernate.HibernateException:/hibernate.cfg.xmlnotfound
atnet.sf.hibernate.cfg.Configuration.getConfigurationInputStream(Configuration.java:886)
atnet.sf.hibernate.cfg.Configuration.configure(Configuration.java:910)
atnet.sf.hibernate.cfg.Configuration.configure(Configuration.java:897)
at javamxj.hibernate.Test.main(Test.java:22)
jackey 发表于2005-07-19 11:05 AM IP: 61.186.252.*
我使用jboss4.2eclipse3.1m7hibername3.0
mysql4.1.8為何會出現此訊息口否告知
感激不盡
og4j:WARNNoappenderscouldbefoundforlogger(org.hibernate.cfg.Environment).
log4j:WARNPleaseinitializethelog4jsystemproperly.
org.hibernate.HibernateException:Couldnotparseconfiguration:/hibernate.cfg.xml
atorg.hibernate.cfg.Configuration.doConfigure(Configuration.java:1148)
atorg.hibernate.cfg.Configuration.configure(Configuration.java:1088)
atorg.hibernate.cfg.Configuration.configure(Configuration.java:1074)
atjavamxj.hibernate.test.main(test.java:14)
Causedby:org.dom4j.DocumentException:Erroronline3ofdocument:Thedocumenttypedeclarationforrootelementtype"hibernate-configuration"mustendwith'>'.Nestedexception:Thedocumenttypedeclarationforrootelementtype"hibernate-configuration"mustendwith'>'.
atorg.dom4j.io.SAXReader.read(SAXReader.java:482)
atorg.hibernate.cfg.Configuration.doConfigure(Configuration.java:1144)
... 3 more
mike1983 发表于2005-07-22 1:25 PM IP:
TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1) 》:
Ping Back来自:blog.csdn.net
吴鹏 发表于2005-09-07 3:16 PM IP: 211.100.21.*
我很喜欢你的blog,我已加入我的blog友情链接
您的这篇文章写的很好,不过我一步步运行下来,最后还是报错,我查遍资料,原来用到cglib这个包的时候需要把asm.jar和asm-attrs.jar包括进来,我包括进来之后就能运行了,也能出现你说的结果了。
欢迎交流
落秋 发表于2005-09-24 12:30 PM IP: 211.100.21.*按图所述,报错如下:
could not find the main class! haihai还请指教是和问题
java.lang.UnsupportedClassVersionError:javamxj/hibernate/Test(Unsupportedmajor.minorversion49.0)
atjava.lang.ClassLoader.defineClass0(NativeMethod)
atjava.lang.ClassLoader.defineClass(ClassLoader.java:537)
atjava.security.SecureClassLoader.defineClass(SecureClassLoader.java:123)
atjava.net.URLClassLoader.defineClass(URLClassLoader.java:251)
atjava.net.URLClassLoader.access$100(URLClassLoader.java:55)
atjava.net.URLClassLoader$1.run(URLClassLoader.java:194)
atjava.security.AccessController.doPrivileged(NativeMethod)
atjava.net.URLClassLoader.findClass(URLClassLoader.java:187)
atjava.lang.ClassLoader.loadClass(ClassLoader.java:289)
atsun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:274)
atjava.lang.ClassLoader.loadClass(ClassLoader.java:235)
atjava.lang.ClassLoader.loadClassInternal(ClassLoader.java:302)
Exception in thread "main"
joes 发表于2005-11-04 11:26 AM IP: 219.137.37.*
感谢javamxj写的文章,写得很详细很精典,对初学者来说真是一大福气。
Falcon 发表于2005-11-21 10:32 AM IP: 59.42.176.*
很好的一篇文章,简洁,易懂,这才叫入门文章
maomao083 发表于2005-12-05 5:48 PM IP: 210.22.158.*太谢谢你了,我完成了你的例子
中间id,username 大小写有一些问题,调试后解决!
还有大家要注意mysql登陆密码,文中设定的
你的这篇文章给我很多信心
要努力在IT 业继续下去
maomao083 发表于2005-12-05 5:48 PM IP: 210.22.158.*太谢谢你了,我完成了你的例子
中间id,username 大小写有一些问题,调试后解决!
还有大家要注意mysql登陆密码,文中设定的
你的这篇文章给我很多信心
要努力在IT 业继续下去
sd-lichangyou 发表于2005-12-08 5:26 PM IP: 218.26.163.*
这篇刚看完,完全可以,多谢了!好文章呀
yhw27del 发表于2005-12-09 3:36 PM IP: 61.51.66.*
我在做的时候出現hibernate.cfg.xml文件沒有被找到,并且拋出異常:
Exceptioncontent:net.sf.hibernate.HibernateException:/hibernate.cfg.xmlnotfound
net.sf.hibernate.HibernateException:/hibernate.cfg.xmlnotfound
atnet.sf.hibernate.cfg.Configuration.getConfigurationInputStream(Configuration.java:886)
atnet.sf.hibernate.cfg.Configuration.configure(Configuration.java:910)
atnet.sf.hibernate.cfg.Configuration.configure(Configuration.java:897)
at javamxj.hibernate.Test.main(Test.java:8)将hibernate.cfg.xml在src目录下问题解决 另外 我用oracle9i库做的,要将oracle9i的jdbc驱动程序ojdbc14.jar放到用户库中,我的jdk是1.4的,如何jdk是1.2或1.3的相应的jdbc驱动程序是class12.jar
kwx 发表于2005-12-29 4:31 PM IP: 219.234.152.*
写得非常棒,照着做了,一次OK!感谢楼主!
peter 发表于2006-02-12 1:37 AM IP: 219.129.11.*帮我看一下下面是什么错误,运行到sess.save(account);就出现错误;谢谢!
01:33:28,502 INFO Environment:479 - Hibernate 3.1.2
01:33:28,522INFOEnvironment:509-hibernate.propertiesnotfound
01:33:28,532INFOEnvironment:525-usingCGLIBreflectionoptimizer
01:33:28,532INFOEnvironment:555-usingJDK1.4java.sql.Timestamphandling
01:33:28,742INFOConfiguration:1308-configuringfromresource:/hibernate.cfg.xml
01:33:28,742INFOConfiguration:1285-Configurationresource:/hibernate.cfg.xml
01:33:29,503INFOConfiguration:469-Readingmappingsfromresource:com/netexam/model/model.hbm.xml
01:33:29,844INFOHbmBinder:309-Mappingclass:com.netexam.model.Account->account
01:33:29,934INFOHbmBinder:309-Mappingclass:com.netexam.model.Question->questionmanager
01:33:29,954INFOHbmBinder:309-Mappingclass:com.netexam.model.TestPaper->testmanager
01:33:29,964INFOHbmBinder:1397-Mappingcollection:com.netexam.model.TestPaper.questions->test
01:33:29,974INFOHbmBinder:309-Mappingclass:com.netexam.model.Answer->answer
01:33:30,174INFOHbmBinder:309-Mappingclass:com.netexam.model.Score->score
01:33:30,194INFOConfiguration:1419-ConfiguredSessionFactory:null
01:33:30,204INFOHbmBinder:2349-Mappingcollection:com.netexam.model.TestPaper.answers->answer
01:33:30,645WARNRootClass:210-composite-idclassdoesnotoverrideequals():com.netexam.model.Score
01:33:30,655WARNRootClass:215-composite-idclassdoesnotoverridehashCode():com.netexam.model.Score
01:33:30,675WARNRootClass:210-composite-idclassdoesnotoverrideequals():com.netexam.model.Answer
01:33:30,675WARNRootClass:215-composite-idclassdoesnotoverridehashCode():com.netexam.model.Answer
01:33:30,685INFODriverManagerConnectionProvider:41-UsingHibernatebuilt-inconnectionpool(notforproductionuse!)
01:33:30,695INFODriverManagerConnectionProvider:42-Hibernateconnectionpoolsize:20
01:33:30,695INFODriverManagerConnectionProvider:45-autocommitmode:false
01:33:30,705INFODriverManagerConnectionProvider:80-usingdriver:com.mysql.jdbc.DriveratURL:jdbc:mysql://localhost:3306/exam?useUnicode=true&characterEncoding=GBK
01:33:30,725INFODriverManagerConnectionProvider:86-connectionproperties:{user=root,password=****}
01:33:31,426INFOSettingsFactory:77-RDBMS:MySQL,version:5.0.18-nt
01:33:31,426INFOSettingsFactory:78-JDBCdriver:MySQL-ABJDBCDriver,version:mysql-connector-java-3.1.12($Date:2005-11-1715:53:48+0100(Thu,17Nov2005)$,$Revision$)
01:33:31,496INFODialect:103-Usingdialect:org.hibernate.dialect.MySQLDialect
01:33:31,506INFOTransactionFactoryFactory:31-Usingdefaulttransactionstrategy(directJDBCtransactions)
01:33:31,516INFOTransactionManagerLookupFactory:33-NoTransactionManagerLookupconfigured(inJTAenvironment,useofread-writeortransactionalsecond-levelcacheisnotrecommended)
01:33:31,526INFOSettingsFactory:125-AutomaticflushduringbeforeCompletion():disabled
01:33:31,526INFOSettingsFactory:129-Automaticsessioncloseatendoftransaction:disabled
01:33:31,526INFOSettingsFactory:136-JDBCbatchsize:15
01:33:31,536INFOSettingsFactory:139-JDBCbatchupdatesforversioneddata:disabled
01:33:31,536INFOSettingsFactory:144-Scrollableresultsets:enabled
01:33:31,536INFOSettingsFactory:152-JDBC3getGeneratedKeys():enabled
01:33:31,536INFOSettingsFactory:160-Connectionreleasemode:auto
01:33:31,546INFOSettingsFactory:184-Maximumouterjoinfetchdepth:2
01:33:31,546INFOSettingsFactory:187-Defaultbatchfetchsize:1
01:33:31,546INFOSettingsFactory:191-GenerateSQLwithcomments:disabled
01:33:31,546INFOSettingsFactory:195-OrderSQLupdatesbyprimarykey:disabled
01:33:31,546INFOSettingsFactory:338-Querytranslator:org.hibernate.hql.ast.ASTQueryTranslatorFactory
01:33:31,596INFOASTQueryTranslatorFactory:24-UsingASTQueryTranslatorFactory
01:33:31,596INFOSettingsFactory:203-Querylanguagesubstitutions:{}
01:33:31,596INFOSettingsFactory:209-Second-levelcache:enabled
01:33:31,596INFOSettingsFactory:213-Querycache:disabled
01:33:31,596INFOSettingsFactory:325-Cacheprovider:org.hibernate.cache.EhCacheProvider
01:33:31,606INFOSettingsFactory:228-Optimizecacheforminimalputs:disabled
01:33:31,606INFOSettingsFactory:237-Structuredsecond-levelcacheentries:disabled
01:33:31,626INFOSettingsFactory:264-Statistics:disabled
01:33:31,626INFOSettingsFactory:268-Deletedentitysyntheticidentifierrollback:disabled
01:33:31,626INFOSettingsFactory:283-Defaultentity-mode:pojo
01:33:31,746INFOSessionFactoryImpl:153-buildingsessionfactory
01:33:31,766WARNConfigurator:126-Noconfigurationfound.Configuringehcachefromehcache-failsafe.xmlfoundintheclasspath:jar:file:/C:/eclipse/workspace/NetExam/lib/ehcache-1.1.jar!/ehcache-failsafe.xml
01:33:32,678INFOSessionFactoryObjectFactory:82-NotbindingfactorytoJNDI,noJNDInameconfigured
Exceptioninthread"main"org.hibernate.HibernateException:Thedatabasereturnednonativelygeneratedidentityvalue
atorg.hibernate.id.IdentifierGeneratorFactory.getGeneratedIdentity(IdentifierGeneratorFactory.java:33)
atorg.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:1970)
atorg.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2405)
atorg.hibernate.action.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:37)
atorg.hibernate.engine.ActionQueue.execute(ActionQueue.java:243)
atorg.hibernate.event.def.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:269)
atorg.hibernate.event.def.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:167)
atorg.hibernate.event.def.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:101)
atorg.hibernate.event.def.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:186)
atorg.hibernate.event.def.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:33)
atorg.hibernate.event.def.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:175)
atorg.hibernate.event.def.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:27)
atorg.hibernate.event.def.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:70)
atorg.hibernate.impl.SessionImpl.fireSave(SessionImpl.java:559)
atorg.hibernate.impl.SessionImpl.save(SessionImpl.java:547)
atorg.hibernate.impl.SessionImpl.save(SessionImpl.java:543)
at com.netexam.model.Test.main(Test.java:38)
leeshaoqun 发表于2006-02-18 7:34 PM IP: 211.100.21.*TrackBack来自《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发 》:
这篇文章是上篇文章《Eclipse快速上手Hibernate--1. 入门实例》的延续,主要说的是如何利用Hbm映射文件产生普通的Java对象及数据表。可以参考Hibernate自带的文档《HIBERNATE - 符合Java习惯的关系数据库持久化》的第15章--《工具箱指南》一节。同样,这篇文章没有过多谈理论,只是给出了一个完整的实例加以说明。相关配置请参考上篇文章。
leeshaoqun 发表于2006-02-18 7:35 PM IP: 211.100.21.*TrackBack来自《Eclipse快速上手Hibernate--3. 利用XDoclet开发 》:
这篇文章是上两篇文章《Eclipse快速上手Hibernate--1. 入门实例》和《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发》的延续,主要说的是如何利用XDocletHbm映射文件产生Hbm映射文件及数据表。可以参考XDoclet文档中关于Hibernate的部分和夏昕编写的《Hibernate开发指南》。同样,这篇文章没有过多谈理论,只是给出了一个完整的实例加以说明。相关配置请参考上两篇文章。
leeshaoqun 发表于2006-02-18 7:36 PM IP: 211.100.21.*TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1) 》:
前面的《Eclipse快速上手Hibernate--1. 入门实例 》等三篇文章已经谈了Hibernate的入门以及利用工具创建的方法。这篇文章主要说说在Hibernate中的继承映射。相关配置请参考前三篇文章。
leeshaoqun 发表于2006-02-18 7:37 PM IP: 211.100.21.*TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(2) 》:
上篇文章《Eclipse快速上手Hibernate--4. 继承映射(1) 》中已经谈了每个类层次结构一个表(table per class hierarchy)的策略,这篇文章主要说的是每个子类一个表(table per subclass)的策略。一些重复的部分这里就不说了,请参考上篇文章。
leeshaoqun 发表于2006-02-18 7:54 PM IP: 211.100.21.*TrackBack来自《快速上手Spring--2.HelloWorld(1)》:
这篇文章主要谈谈Spring的入门开发,例子很简单,就是输出一条语句。有关各种软件的配置这里就不在多说了,如有不明白的,可以参考我以前的文章。
冰云 发表于2006-02-22 10:39 AM IP: 211.100.21.*TrackBack来自《Eclipse快速上手Hibernate--1. 入门实例 》:
http://blog.csdn.net/javamxj/archive/2005/04/02/335076.aspx
rinso 发表于2006-03-22 6:34 PM IP: 211.100.21.*TrackBack来自《Eclipse快速上手Hibernate--3. 利用XDoclet开发 》:
这篇文章是上两篇文章《Eclipse快速上手Hibernate--1. 入门实例》和《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发》的延续,主要说的是如何利用XDocletHbm映射文件产生Hbm映射文件及数据表。可以参考XDoclet文档中关于Hibernate的部分和夏昕编写的《Hibernate开发指南》。同样,这篇文章没有过多谈理论,只是给出了一个完整的实例加以说明。相关配置请参考上两篇文章。
小雨 发表于2006-04-10 11:30 AM IP: 210.45.244.*运行test.java时出现的问题
java.lang.ExceptionInInitializerError
atjavamxj.hibernate.Test.main(Test.java:17)
Causedby:org.apache.commons.logging.LogConfigurationException:org.apache.commons.logging.LogConfigurationException:java.lang.NullPointerException(Causedbyjava.lang.NullPointerException)(Causedbyorg.apache.commons.logging.LogConfigurationException:java.lang.NullPointerException(Causedbyjava.lang.NullPointerException))
atorg.apache.commons.logging.impl.LogFactoryImpl.newInstance(LogFactoryImpl.java:543)
atorg.apache.commons.logging.impl.LogFactoryImpl.getInstance(LogFactoryImpl.java:235)
atorg.apache.commons.logging.impl.LogFactoryImpl.getInstance(LogFactoryImpl.java:209)
atorg.apache.commons.logging.LogFactory.getLog(LogFactory.java:351)
atnet.sf.hibernate.cfg.Configuration.<clinit>(Configuration.java:94)
...1more
Causedby:org.apache.commons.logging.LogConfigurationException:java.lang.NullPointerException(Causedbyjava.lang.NullPointerException)
atorg.apache.commons.logging.impl.LogFactoryImpl.getLogConstructor(LogFactoryImpl.java:397)
atorg.apache.commons.logging.impl.LogFactoryImpl.newInstance(LogFactoryImpl.java:529)
...5more
Causedby:java.lang.NullPointerException
atorg.apache.commons.logging.impl.LogFactoryImpl.getLogConstructor(LogFactoryImpl.java:374)
...6more
Exception in thread "main"
steven 发表于2006-05-16 3:40 PM IP: 222.64.106.*
hibernate.cfg.xml不是在javamxj.hibernate包下而是和javamxj.hibernate在同一个目录.在java环境的classpath下,即上面环境的src下面.
任海夸 发表于2006-05-18 11:54 PM IP: 124.147.159.*
Exceptioninthread"main"java.lang.NoClassDefFoundError:net/sf/ehcache/CacheException
atjava.lang.Class.getDeclaredConstructors0(NativeMethod)
atjava.lang.Class.privateGetDeclaredConstructors(UnknownSource)
atjava.lang.Class.getConstructor0(UnknownSource)
atjava.lang.Class.newInstance0(UnknownSource)
atjava.lang.Class.newInstance(UnknownSource)
atnet.sf.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:142)
atnet.sf.hibernate.cfg.Configuration.buildSettings(Configuration.java:1172)
atnet.sf.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:803)
atjavamxj.hibernate.Test.main(Test.java:14)
哪位能不告诉我这是什么错?
谢谢了