Hibernate学习

sysuqgy 2011-05-19

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&amp;characterEncoding=GBK"表示使用GBK进行编码-->

<propertyname="connection.url">

jdbc:mysql://localhost:3306/HibernateTest?useUnicode=true&amp;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: 20

Exception 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)

哪位能不告诉我这是什么错?

谢谢了

相关推荐

LetonLIU / 0评论 2020-05-29
东方咖啡屋 / 0评论 2020-01-06