- 浏览: 64890 次
- 性别:
- 来自: 北京
文章分类
最新评论
1. 入门实例 - "+document.title
这篇文章主要谈谈Hibernate的入门开发,例子很简单,就是向数据表中添加用户名和密码。我分别使用了三种方法,一种是直接写代码,写Hbm映射文件等;一种是通过Hbm映射文件来生成代码;一种是通过代码来生成Hbm映射文件。使用了一些自动化工具,XMLBuddy是用来编辑XML文件的,JBoss Eclipse IDE是用来编写Doclet标记的。这篇文章还谈到了一些Eclipse的使用技巧,比如建立“用户库”、“生成 Getter 和 Setter”等。
关于一些软件的使用技巧,我以前的文章都有提及,这里不多说了,必要时会提示一下。
一、下载、安装和配置
1. 所需软件
● Ant 1.6.2 http://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
● JBoss Eclipse IDE http://www.jboss.org/products/jbosside
看看说明,需要挑选与使用的eclipse相对应的版本,这里选择JBossIDE-1.4.1-e30.zip,这是它的镜像下载地址:
http://prdownloads.sourceforge.net/jboss/JBossIDE-1.4.1-e30.zip?download
● Hibernate http://www.hibernate.org/
下载 Hibernate 2.1.8
http://prdownloads.sourceforge.net/hibernate/hibernate-2.1.8.zip?download
同时也要把 Hibernate Extensions 2.1.3 下载了,它包含一些工具类。
下载 http://prdownloads.sourceforge.net/hibernate/hibernate-extensions-2.1.3.zip?download
● MySQL 4.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.jar cglib-full-2.0.2.jar commons-collections-2.1.1.jar commons-logging-1.0.4.jar commons-lang-1.0.1.jar dom4j-1.4.jar ehcache-0.9.jar log4j-1.2.8.jar odmg-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
* @author javamxj(分享java快乐)
* @link Blog: htpp://javamxj.mblogger.cn
* htpp://blog.csdn.net/javamxj/
*/
package javamxj.hibernate;
public class User {
private int id;
private String username;
private String password;
}
· 点击工具栏上的“源代码(S)”,选择其中的“生成 Getter 和 Setter”(右击,在弹出菜单也可选择),如图:
点击“确定”后,生成如下代码:
/*
* 采用常规方法开发一个简单的Hibernate实例
* 创建日期 2005-3-31
* @author javamxj(分享java快乐)
* @link Blog: htpp://javamxj.mblogger.cn
* htpp://blog.csdn.net/javamxj/
*/
package javamxj.hibernate;
public class User {
private int id;
private String username;
private String password;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
}
好了,这个类完成了。它是一个普通的Java对象(Plain Old Java Objects,就是POJOs,有时候也称作Plain Ordinary Java Objects),表示一个数据集合。下面建立一个Hbm文件将这个类映射到数据库的表格上。
3. 映射文件
在javamxj.hibernate包下,新建一个名称为“User.hbm.xml”的文件,使用XMLBuddy编辑它(参考:利用XMLBuddy在Eclipse中开发XML ),这样比较方便。文件内容如下:
<?xml version="1.0" encoding="GBK"?>
<!DOCTYPE hibernate-mapping
PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">
<hibernate-mapping>
<class name="javamxj.hibernate.User" table="UserTable">
<id name="id">
<generator class="assigned" />
</id>
<property name="username" />
<property name="password" />
</class>
</hibernate-mapping>
这个XML文件定义了对象属性映射到数据库表的关系,这里采用了assigned(程序设置)方式生成主键。当然还可以使用其它的方式来产生主键,后面的文章就采用了其它的方式产生主键。
<property>标签用于定义Java对象的属性,这里只定义了最简单的方式,由Hibernate自动判断Java对象属性与数据库表名称对应关系。在<property/>标签上的额外设定(像是not null、sql-type等),则可以用于自动产生Java对象与数据库表的工具上。
4. 配置文件
Hibernate可以使用XML或属性文件来进行配置,配置文件名默认为“hibernate.cfg.xml”(或者hibernate.properties)。
在src目录下,新建一个hibernate.cfg.xml文件,内容如下:
<?xml version='1.0' encoding='GBK'?>
<!DOCTYPE hibernate-configuration
PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 是否将运行期生成的SQL输出到日志以供调试 -->
<property name="show_sql">true</property>
<!-- SQL方言,这里设定的是MySQL -->
<property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property>
<!-- JDBC驱动程序 -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- JDBC URL, "?useUnicode=true&characterEncoding=GBK" 表示使用GBK进行编码 -->
<property name="connection.url">
jdbc:mysql://localhost:3306/HibernateTest?useUnicode=true&characterEncoding=GBK
</property>
<!-- 数据库用户名 -->
<property name="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
* @author javamxj(分享java快乐)
*/
package javamxj.hibernate;
import net.sf.hibernate.*;
import net.sf.hibernate.cfg.*;
public class Test {
public static void main(String[] args) {
try {
SessionFactory sf = new Configuration().configure()
.buildSessionFactory();
Session session = 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语句如下:
CREATE TABLE usertable (
ID int(6) NOT NULL auto_increment,
username varchar(24) NOT NULL default '',
password varchar(24) NOT NULL default '',
PRIMARY KEY (ID)
);
这里,HibernateTest与hibernate.cfg.xml配置文件中的HibernateTest相对应,UserTable与hbm映射文件中的UserTable相对应。
7. 运行程序
右击Test.java,点击运行,可以看到控制台输出一系列信息,最后一条输出语句应该是:
Hibernate: insert into UserTable (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.*
To esmiles:
设置“构建路径”是为了与后面文章中的build.xml相配合
super2 发表于2005-05-02 4:24 PM IP: 61.167.132.*
(cfg.Environment 483 ) Hibernate 2.1.8
(cfg.Environment 512 ) hibernate.properties not found
(cfg.Environment 543 ) using CGLIB reflection optimizer
(cfg.Environment 572 ) using JDK 1.4 java.sql.Timestamp handling
(cfg.Configuration 909 ) configuring from resource: /hibernate.cfg.xml
(cfg.Configuration 881 ) Configuration resource: /hibernate.cfg.xml
(cfg.Configuration 332 ) Mapping resource: xzl/hibernate/user.hbm.xml
(cfg.Binder 229 ) Mapping class: xzl.hibernate.User -> usertable
(cfg.Configuration 1067) Configured SessionFactory: null
(cfg.Configuration 641 ) processing one-to-many association mappings
(cfg.Configuration 650 ) processing one-to-one association property references
(cfg.Configuration 675 ) processing foreign key constraints
(dialect.Dialect 86 ) Using dialect: net.sf.hibernate.dialect.MySQLDialect
(cfg.SettingsFactory 70 ) Maximim outer join fetch depth: 2
(cfg.SettingsFactory 74 ) Use outer join fetching: true
(connection.DriverManagerConnectionProvider 42 ) Using Hibernate built-in connection pool (not for production use!)
(connection.DriverManagerConnectionProvider 43 ) Hibernate connection pool size: 20
Exception in thread "main" java.lang.NoClassDefFoundError: org/aspectj/lang/Signature
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:164)
at net.sf.hibernate.connection.DriverManagerConnectionProvider.configure(DriverManagerConnectionProvider.java:55)
at net.sf.hibernate.connection.ConnectionProviderFactory.newConnectionProvider(ConnectionProviderFactory.java:83)
at net.sf.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:76)
at net.sf.hibernate.cfg.Configuration.buildSettings(Configuration.java:1172)
at net.sf.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:803)
at xzl.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:WARN No appenders could be found for logger (net.sf.hibernate.cfg.Environment).
log4j:WARN Please initialize the log4j system properly.
Hibernate: insert into usertable (username, password, id) values (?, ?, ?)
Exception in thread "main" java.lang.StringIndexOutOfBoundsException: String index out of range: 10
at java.lang.String.charAt(String.java:558)
at com.mysql.jdbc.StringUtils.escapeSJISByteStream(StringUtils.java:280)
at com.mysql.jdbc.StringUtils.getBytes(StringUtils.java:105)
at com.mysql.jdbc.PreparedStatement.setString(PreparedStatement.java:1068)
at net.sf.hibernate.type.StringType.set(StringType.java:26)
at net.sf.hibernate.type.NullableType.nullSafeSet(NullableType.java:48)
at net.sf.hibernate.type.NullableType.nullSafeSet(NullableType.java:35)
at net.sf.hibernate.persister.EntityPersister.dehydrate(EntityPersister.java:389)
at net.sf.hibernate.persister.EntityPersister.insert(EntityPersister.java:462)
at net.sf.hibernate.persister.EntityPersister.insert(EntityPersister.java:438)
at net.sf.hibernate.impl.ScheduledInsertion.execute(ScheduledInsertion.java:37)
at net.sf.hibernate.impl.SessionImpl.executeAll(SessionImpl.java:2438)
at net.sf.hibernate.impl.SessionImpl.execute(SessionImpl.java:2391)
at net.sf.hibernate.impl.SessionImpl.flush(SessionImpl.java:2260)
at net.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文件沒有被找到,并且拋出異常:
Exception content:net.sf.hibernate.HibernateException: /hibernate.cfg.xml not found
net.sf.hibernate.HibernateException: /hibernate.cfg.xml not found
at net.sf.hibernate.cfg.Configuration.getConfigurationInputStream(Configuration.java:886)
at net.sf.hibernate.cfg.Configuration.configure(Configuration.java:910)
at net.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.*
To qinfen:
没有更多的信息,我也不清楚你的错误原因,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包下,可是還是發生了這個錯誤訊息,請問你有解決之道嗎?
Error Message:
(cfg.Environment 483 ) Hibernate 2.1.8
(cfg.Environment 512 ) hibernate.properties not found
(cfg.Environment 543 ) using CGLIB reflection optimizer
(cfg.Environment 572 ) using JDK 1.4 java.sql.Timestamp handling
(cfg.Configuration 909 ) configuring from resource: /hibernate.cfg.xml
(cfg.Configuration 881 ) Configuration resource: /hibernate.cfg.xml
(cfg.Configuration 885 ) /hibernate.cfg.xml not found
net.sf.hibernate.HibernateException: /hibernate.cfg.xml not found
at net.sf.hibernate.cfg.Configuration.getConfigurationInputStream(Configuration.java:886)
at net.sf.hibernate.cfg.Configuration.configure(Configuration.java:910)
at net.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.*
我使用 jboss 4.2 eclipse 3.1m7 hibername 3.0
mysql 4.1.8 為何會出現此訊息 口否告知
感激不盡
og4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment).
log4j:WARN Please initialize the log4j system properly.
org.hibernate.HibernateException: Could not parse configuration: /hibernate.cfg.xml
at org.hibernate.cfg.Configuration.doConfigure(Configuration.java:1148)
at org.hibernate.cfg.Configuration.configure(Configuration.java:1088)
at org.hibernate.cfg.Configuration.configure(Configuration.java:1074)
at javamxj.hibernate.test.main(test.java:14)
Caused by: org.dom4j.DocumentException: Error on line 3 of document : The document type declaration for root element type "hibernate-configuration" must end with '>'. Nested exception: The document type declaration for root element type "hibernate-configuration" must end with '>'.
at org.dom4j.io.SAXReader.read(SAXReader.java:482)
at org.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 (Unsupported major.minor version 49.0)
at java.lang.ClassLoader.defineClass0(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:537)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:123)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:251)
at java.net.URLClassLoader.access$100(URLClassLoader.java:55)
at java.net.URLClassLoader$1.run(URLClassLoader.java:194)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:187)
at java.lang.ClassLoader.loadClass(ClassLoader.java:289)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:274)
at java.lang.ClassLoader.loadClass(ClassLoader.java:235)
at java.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文件沒有被找到,并且拋出異常:
Exception content:net.sf.hibernate.HibernateException: /hibernate.cfg.xml not found
net.sf.hibernate.HibernateException: /hibernate.cfg.xml not found
at net.sf.hibernate.cfg.Configuration.getConfigurationInputStream(Configuration.java:886)
at net.sf.hibernate.cfg.Configuration.configure(Configuration.java:910)
at net.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,522 INFO Environment:509 - hibernate.properties not found
01:33:28,532 INFO Environment:525 - using CGLIB reflection optimizer
01:33:28,532 INFO Environment:555 - using JDK 1.4 java.sql.Timestamp handling
01:33:28,742 INFO Configuration:1308 - configuring from resource: /hibernate.cfg.xml
01:33:28,742 INFO Configuration:1285 - Configuration resource: /hibernate.cfg.xml
01:33:29,503 INFO Configuration:469 - Reading mappings from resource: com/netexam/model/model.hbm.xml
01:33:29,844 INFO HbmBinder:309 - Mapping class: com.netexam.model.Account -> account
01:33:29,934 INFO HbmBinder:309 - Mapping class: com.netexam.model.Question -> questionmanager
01:33:29,954 INFO HbmBinder:309 - Mapping class: com.netexam.model.TestPaper -> testmanager
01:33:29,964 INFO HbmBinder:1397 - Mapping collection: com.netexam.model.TestPaper.questions -> test
01:33:29,974 INFO HbmBinder:309 - Mapping class: com.netexam.model.Answer -> answer
01:33:30,174 INFO HbmBinder:309 - Mapping class: com.netexam.model.Score -> score
01:33:30,194 INFO Configuration:1419 - Configured SessionFactory: null
01:33:30,204 INFO HbmBinder:2349 - Mapping collection: com.netexam.model.TestPaper.answers -> answer
01:33:30,645 WARN RootClass:210 - composite-id class does not override equals(): com.netexam.model.Score
01:33:30,655 WARN RootClass:215 - composite-id class does not override hashCode(): com.netexam.model.Score
01:33:30,675 WARN RootClass:210 - composite-id class does not override equals(): com.netexam.model.Answer
01:33:30,675 WARN RootClass:215 - composite-id class does not override hashCode(): com.netexam.model.Answer
01:33:30,685 INFO DriverManagerConnectionProvider:41 - Using Hibernate built-in connection pool (not for production use!)
01:33:30,695 INFO DriverManagerConnectionProvider:42 - Hibernate connection pool size: 20
01:33:30,695 INFO DriverManagerConnectionProvider:45 - autocommit mode: false
01:33:30,705 INFO DriverManagerConnectionProvider:80 - using driver: com.mysql.jdbc.Driver at URL: jdbc:mysql://localhost:3306/exam?useUnicode=true&characterEncoding=GBK
01:33:30,725 INFO DriverManagerConnectionProvider:86 - connection properties: {user=root, password=****}
01:33:31,426 INFO SettingsFactory:77 - RDBMS: MySQL, version: 5.0.18-nt
01:33:31,426 INFO SettingsFactory:78 - JDBC driver: MySQL-AB JDBC Driver, version: mysql-connector-java-3.1.12 ( $Date: 2005-11-17 15:53:48 +0100 (Thu, 17 Nov 2005) $, $Revision$ )
01:33:31,496 INFO Dialect:103 - Using dialect: org.hibernate.dialect.MySQLDialect
01:33:31,506 INFO TransactionFactoryFactory:31 - Using default transaction strategy (direct JDBC transactions)
01:33:31,516 INFO TransactionManagerLookupFactory:33 - No TransactionManagerLookup configured (in JTA environment, use of read-write or transactional second-level cache is not recommended)
01:33:31,526 INFO SettingsFactory:125 - Automatic flush during beforeCompletion(): disabled
01:33:31,526 INFO SettingsFactory:129 - Automatic session close at end of transaction: disabled
01:33:31,526 INFO SettingsFactory:136 - JDBC batch size: 15
01:33:31,536 INFO SettingsFactory:139 - JDBC batch updates for versioned data: disabled
01:33:31,536 INFO SettingsFactory:144 - Scrollable result sets: enabled
01:33:31,536 INFO SettingsFactory:152 - JDBC3 getGeneratedKeys(): enabled
01:33:31,536 INFO SettingsFactory:160 - Connection release mode: auto
01:33:31,546 INFO SettingsFactory:184 - Maximum outer join fetch depth: 2
01:33:31,546 INFO SettingsFactory:187 - Default batch fetch size: 1
01:33:31,546 INFO SettingsFactory:191 - Generate SQL with comments: disabled
01:33:31,546 INFO SettingsFactory:195 - Order SQL updates by primary key: disabled
01:33:31,546 INFO SettingsFactory:338 - Query translator: org.hibernate.hql.ast.ASTQueryTranslatorFactory
01:33:31,596 INFO ASTQueryTranslatorFactory:24 - Using ASTQueryTranslatorFactory
01:33:31,596 INFO SettingsFactory:203 - Query language substitutions: {}
01:33:31,596 INFO SettingsFactory:209 - Second-level cache: enabled
01:33:31,596 INFO SettingsFactory:213 - Query cache: disabled
01:33:31,596 INFO SettingsFactory:325 - Cache provider: org.hibernate.cache.EhCacheProvider
01:33:31,606 INFO SettingsFactory:228 - Optimize cache for minimal puts: disabled
01:33:31,606 INFO SettingsFactory:237 - Structured second-level cache entries: disabled
01:33:31,626 INFO SettingsFactory:264 - Statistics: disabled
01:33:31,626 INFO SettingsFactory:268 - Deleted entity synthetic identifier rollback: disabled
01:33:31,626 INFO SettingsFactory:283 - Default entity-mode: pojo
01:33:31,746 INFO SessionFactoryImpl:153 - building session factory
01:33:31,766 WARN Configurator:126 - No configuration found. Configuring ehcache from ehcache-failsafe.xml found in the classpath: jar:file:/C:/eclipse/workspace/NetExam/lib/ehcache-1.1.jar!/ehcache-failsafe.xml
01:33:32,678 INFO SessionFactoryObjectFactory:82 - Not binding factory to JNDI, no JNDI name configured
Exception in thread "main" org.hibernate.HibernateException: The database returned no natively generated identity value
at org.hibernate.id.IdentifierGeneratorFactory.getGeneratedIdentity(IdentifierGeneratorFactory.java:33)
at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:1970)
at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2405)
at org.hibernate.action.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:37)
at org.hibernate.engine.ActionQueue.execute(ActionQueue.java:243)
at org.hibernate.event.def.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:269)
at org.hibernate.event.def.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:167)
at org.hibernate.event.def.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:101)
at org.hibernate.event.def.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:186)
at org.hibernate.event.def.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:33)
at org.hibernate.event.def.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:175)
at org.hibernate.event.def.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:27)
at org.hibernate.event.def.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:70)
at org.hibernate.impl.SessionImpl.fireSave(SessionImpl.java:559)
at org.hibernate.impl.SessionImpl.save(SessionImpl.java:547)
at org.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
at javamxj.hibernate.Test.main(Test.java:17)
Caused by: org.apache.commons.logging.LogConfigurationException: org.apache.commons.logging.LogConfigurationException: java.lang.NullPointerException (Caused by java.lang.NullPointerException) (Caused by org.apache.commons.logging.LogConfigurationException: java.lang.NullPointerException (Caused by java.lang.NullPointerException))
at org.apache.commons.logging.impl.LogFactoryImpl.newInstance(LogFactoryImpl.java:543)
at org.apache.commons.logging.impl.LogFactoryImpl.getInstance(LogFactoryImpl.java:235)
at org.apache.commons.logging.impl.LogFactoryImpl.getInstance(LogFactoryImpl.java:209)
at org.apache.commons.logging.LogFactory.getLog(LogFactory.java:351)
at net.sf.hibernate.cfg.Configuration.<clinit>(Configuration.java:94)
... 1 more
Caused by: org.apache.commons.logging.LogConfigurationException: java.lang.NullPointerException (Caused by java.lang.NullPointerException)
at org.apache.commons.logging.impl.LogFactoryImpl.getLogConstructor(LogFactoryImpl.java:397)
at org.apache.commons.logging.impl.LogFactoryImpl.newInstance(LogFactoryImpl.java:529)
... 5 more
Caused by: java.lang.NullPointerException
at org.apache.commons.logging.impl.LogFactoryImpl.getLogConstructor(LogFactoryImpl.java:374)
... 6 more
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.*
Exception in thread "main" java.lang.NoClassDefFoundError: net/sf/ehcache/CacheException
at java.lang.Class.getDeclaredConstructors0(Native Method)
at java.lang.Class.privateGetDeclaredConstructors(Unknown Source)
at java.lang.Class.getConstructor0(Unknown Source)
at java.lang.Class.newInstance0(Unknown Source)
at java.lang.Class.newInstance(Unknown Source)
at net.sf.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:142)
at net.sf.hibernate.cfg.Configuration.buildSettings(Configuration.java:1172)
at net.sf.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:803)
at javamxj.hibernate.Test.main(Test.java:14)
哪位能不告诉我这是什么错?
谢谢了
相关推荐
【hibernate学习资料大全】 Hibernate 是一个开源的对象关系映射(ORM)框架,它极大地简化了Java应用程序对数据库的操作。这个压缩包包含了丰富的Hibernate学习资源,旨在帮助开发者深入理解和熟练掌握这一强大的...
<br>搜集清单和说明 1:hibernate学习源码,这是我以前做练习的代码,希望对感兴趣的朋友 有些帮助。 2:hibernate_reference.pdf,我以前学习参看的资料。 3:hibernate源码.zip,hibernate的源...
### Hibernate学习知识点详解 #### 1. Hibernate简介与安装配置 **标题:** Hibernate学习 **描述:** Hibernate 学习 Hibernate学习.pdf **标签:** Hibernate 学习 Hibernate学习.pdf **知识点详解:** ####...
Hibernate学习笔记整理 以下是 Hibernate 框架的详细知识点: Hibernate 介绍 Hibernate 是一个 ORM(Object-Relational Mapping)框架,用于将 Java 对象映射到数据库表中。它提供了一个简洁的方式来访问和操作...
《Hibernate学习笔记特别详细》 Hibernate,作为一款开源的Object-Relational Mapping(ORM)框架,为Java开发者提供了强大的数据库操作支持。它简化了数据库访问的复杂性,使得开发人员可以像操作对象一样操作...
《Hibernate学习文档集合》 Hibernate,作为Java领域中的一款强大且广泛应用的对象关系映射(ORM)框架,极大地简化了数据库操作。本集合包含了三个关键的学习文档,分别关注于Hibernate的操作基础、对象关系映射和...
**hibernate学习资料大合集** 本资料合集涵盖了关于Hibernate的各种学习资源,包括PDF、CHM和Word文档,旨在帮助开发者深入理解和掌握Hibernate这一强大的Java持久化框架。Hibernate作为一个对象关系映射(ORM)...
《Hibernate学习精华》 Hibernate,一个开放源代码的对象关系映射框架,是Java开发者在数据库操作中不可或缺的工具。它简化了Java应用与数据库之间的交互,使得开发人员能够以面向对象的方式来处理数据库操作,极大...
**Hibernate学习笔记与大纲** Hibernate 是一款开源的Java语言下的对象关系映射(ORM)框架,它极大地简化了数据库操作,使得开发人员可以使用面向对象的方式处理数据,而无需过多关注底层的SQL语句。本笔记将深入...
**hibernate学习笔记第四天源码解析** 在hibernate学习的过程中,第四天通常会深入探讨实体类、映射文件、配置文件以及查询语言等方面的内容。这些是hibernate框架的基础,也是开发者掌握持久化操作的关键。让我们...
《Hibernate学习文档》 Hibernate是一种广泛应用于Java开发中的对象关系映射(ORM)框架,它的核心价值在于简化了数据库操作,通过将Java对象模型与SQL关系模型进行映射,使得开发者可以使用面向对象的方式来处理...
对于初学者来说,学习 Hibernate 可以简化数据库操作,提高开发效率。以下是对 Hibernate 学习过程的详细说明: 一、配置 Hibernate 与 MyEclipse 连接 在开始使用 Hibernate 之前,你需要先配置 Hibernate 与...
在本篇《Hibernate学习笔记》中,我们将深入探讨Hibernate这一流行的Java对象关系映射(ORM)框架。Hibernate允许开发者以面向对象的方式处理数据库操作,极大地简化了数据存取的复杂性。以下是一些关键知识点: 1....
Hibernate学习笔记 Hibernate学习笔记 Hibernate学习笔记 Hibernate学习笔记
【Java相关课程系列笔记之十四Hibernate学习笔记】 Hibernate是一个开源的对象关系映射(ORM)框架,它极大地简化了Java应用程序对数据库的操作。本笔记将详细阐述Hibernate的核心概念、使用方法和特性。 一、...
**Hibernate 框架概述** Hibernate 是一个开源的对象关系映射(ORM)框架,它为 Java 开发者提供了一种在 Java 应用程序中管理关系...通过实践和深入学习,你可以更好地利用 Hibernate 实现高效、可靠的数据库应用。
在“hibernate学习资料”中,我们可以看到两个关键文件:“hibernate┐≥╝▄┐¬╖ó2016░µ╫╩┴╧”和“hibernate框架开发2016版资料”。这些文件很可能是针对Hibernate框架的教程或指南,可能包含了2016年时的...
这个“Hibernate学习代码示例”压缩包文件为初学者提供了丰富的学习资源,帮助他们理解并掌握Hibernate的核心概念和实际应用。 首先,让我们详细探讨一下Hibernate的基础知识。Hibernate是一个开源的ORM框架,它的...