Hibernate学习


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&amp;characterEncoding=GBK" 表示使用GBK进行编码 -->
        <property name="connection.url">
   jdbc:mysql://localhost:3306/HibernateTest?useUnicode=true&amp;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)
哪位能不告诉我这是什么错?
谢谢了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值