分享Java快乐

我有一份快乐,分给你一些;我还是有一份快乐,你也有一份快乐。

mxj ID:javamxj
517724次访问,排名75好友0人,关注者5
javamxj的文章
原创 82 篇
翻译 0 篇
转载 0 篇
评论 720 篇
javamxj的公告

    版权声明:在此发表的有关文章均属本人javamxj原创,转摘或引用请注明出处。



联系方式:
Email:
javamxj@gmail.com

友情Blog

最近评论
linuxghs:删除configuration,eclipse不能启动了。郁闷
xinghui100:学习中
IvonXiao:谢谢博主的分享
xkpkhu:wow power leveling
xkpkhu:wow power leveling
文章分类
收藏
    相册
    有空逛逛
    java开源大全(RSS)
    存档
    软件项目交易
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    原创 Eclipse快速上手Hibernate--1. 入门实例收藏

    新一篇: Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发 | 旧一篇: 狡兔三窟--第二窟

        这篇文章主要谈谈Hibernate的入门开发,例子很简单,就是向数据表中添加用户名和密码。我分别使用了三种方法,一种是直接写代码,写Hbm映射文件等;一种是通过Hbm映射文件来生成代码;一种是通过代码来生成Hbm映射文件。使用了一些自动化工具,XMLBuddy是用来编辑XML文件的,JBoss Eclipse IDE是用来编写Doclet标记的。这篇文章还谈到了一些Eclipse的使用技巧,比如建立“用户库”、“生成 Getter 和 Setter”等。
     
       关于一些软件的使用技巧,我以前的文章都有提及,这里不多说了,必要时会提示一下。
       
     
     
    1. 所需软件
    Ant 1.6.2        http://ant.apache.org
     
     Eclipse 3.0.1 及 语言包
     
     
    XMLBuddy          http://www.xmlbuddy.com/
        下载             XMLBuddy 2.0.38   
     
       看看说明,需要挑选与使用的eclipse相对应的版本,这里选择JBossIDE-1.4.1-e30.zip,这是它的镜像下载地址:
     
    Hibernate         http://www.hibernate.org/
         下载            Hibernate 2.1.8
     
       同时也要把 Hibernate Extensions 2.1.3 下载了,它包含一些工具类。
     
     
    ●  MySQL 4.1.8
         注意需要mysql-connector-java-3.0.16-ga-bin.jar文件
     
     
     
    2. 安装和配置 
     
        这里着重指出一下,需要在环境变量中设置 ANT_HOME ,并将其指向Ant安装目录,还要在Path变量值中添加 “%ANT_HOME%\bin;” 可以参考 java环境变量设置
     
     · XMLBuddy 和Jboss-ide 我都是采用links方式安装的,
     
    ●  建立库文件夹:
     
       在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,理论方面我不想过多纠缠,尽量以实例说话。我想,与其凭空说一个技术多好多好,倒不如给我一个可以上手的实例操作一下。好了,不多说废话了。
     
      
     

    发表于 @ 2005年04月02日 15:26:00|评论(loading...)|编辑

    新一篇: Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发 | 旧一篇: 狡兔三窟--第二窟

    评论

    #javamxj 发表于2005-04-04 14:40:00  IP:
    TrackBack来自《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发》

    Ping Back来自:blog.csdn.net
    #javamxj 发表于2005-04-05 16:47:00  IP:
    TrackBack来自《Eclipse快速上手Hibernate--3. 利用XDoclet开发 》

    Ping Back来自:blog.csdn.net
    #javamxj 发表于2005-04-13 00:03:00  IP:
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(3) 》

    Ping Back来自:blog.csdn.net
    #javamxj 发表于2005-04-11 00:22:00  IP:
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1)》

    Ping Back来自:blog.csdn.net
    #javamxj 发表于2005-04-11 00:22:00  IP:
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1)》

    Ping Back来自:blog.csdn.net
    #zesila_80 发表于2005-06-22 09:30:00  IP:
    TrackBack来自《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发(摘自javamxj的blog)》

    Ping Back来自:blog.csdn.net
    #zesila_80 发表于2005-06-22 09:34:00  IP:
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1)(摘自javamxj的blog)》

    Ping Back来自:blog.csdn.net
    #zesila_80 发表于2005-06-22 09:37:00  IP:
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(3)(摘自javamxj的blog)》

    Ping Back来自:blog.csdn.net
    #javamxj 发表于2005-06-26 12:21:00  IP:
    TrackBack来自《快速上手Spring--2.HelloWorld(1)》

    Ping Back来自:blog.csdn.net
    #fqcheng 发表于2005-06-28 09:37:00  IP:
    TrackBack来自《快速上手Spring--2.HelloWorld(1) 》

    Ping Back来自:blog.csdn.net
    #mike1983 发表于2005-07-22 13:25:00  IP:
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1) 》

    Ping Back来自:blog.csdn.net
    #leeshaoqun 发表于2006-02-18 19:34:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发 》

    这篇文章是上篇文章《Eclipse快速上手Hibernate--1. 入门实例》的延续,主要说的是如何利用Hbm映射文件产生普通的Java对象及数据表。可以参考Hibernate自带的文档《HIBERNATE - 符合Java习惯的关系数据库持久化》的第15章--《工具箱指南》一节。同样,这篇文章没有过多谈理论,只是给出了一个完整的实例加以说明。相关配置请参考上篇文章。
    #leeshaoqun 发表于2006-02-18 19:35:00  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 19:36:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1) 》

    前面的《Eclipse快速上手Hibernate--1. 入门实例 》等三篇文章已经谈了Hibernate的入门以及利用工具创建的方法。这篇文章主要说说在Hibernate中的继承映射。相关配置请参考前三篇文章。
    #leeshaoqun 发表于2006-02-18 19:37:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(2) 》

    上篇文章《Eclipse快速上手Hibernate--4. 继承映射(1) 》中已经谈了每个类层次结构一个表(table per class hierarchy)的策略,这篇文章主要说的是每个子类一个表(table per subclass)的策略。一些重复的部分这里就不说了,请参考上篇文章。
    #leeshaoqun 发表于2006-02-18 19:54:00  IP: 211.100.21.*
    TrackBack来自《快速上手Spring--2.HelloWorld(1)》

    这篇文章主要谈谈Spring的入门开发,例子很简单,就是输出一条语句。有关各种软件的配置这里就不在多说了,如有不明白的,可以参考我以前的文章。
    #冰云 发表于2006-02-22 10:39:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--1. 入门实例 》

    http://blog.csdn.net/javamxj/archive/2005/04/02/335076.aspx
    #rinso 发表于2006-03-22 18:34:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--3. 利用XDoclet开发 》

    这篇文章是上两篇文章《Eclipse快速上手Hibernate--1. 入门实例》和《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发》的延续,主要说的是如何利用XDocletHbm映射文件产生Hbm映射文件及数据表。可以参考XDoclet文档中关于Hibernate的部分和夏昕编写的《Hibernate开发指南》。同样,这篇文章没有过多谈理论,只是给出了一个完整的实例加以说明。相关配置请参考上两篇文章。
    #kxtk 发表于2006-06-09 19:00:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--3. 利用XDoclet开发》

    这篇文章是上两篇文章《Eclipse快速上手Hibernate--1. 入门实例》和《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发》的延续,主要说的是如何利用XDocletHbm映射文件产生Hbm映射文件及数据表。可以参考XDoclet文档中关于Hibernate的部分和夏昕编写的《Hibernate开发指南》。同样,这篇文章没有过多谈理论,只是给出了一个完整的实例加以说明。相关配置请参考上两篇文章。
    #kxtk 发表于2006-06-09 19:03:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1) -》

    前面的《Eclipse快速上手Hibernate--1. 入门实例 》等三篇文章已经谈了Hibernate的入门以及利用工具创建的方法。这篇文章主要说说在Hibernate中的继承映射。相关配置请参考前三篇文章。
    #kxtk 发表于2006-06-09 18:49:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发 》

    这篇文章是上篇文章《Eclipse快速上手Hibernate--1. 入门实例》的延续,主要说的是如何利用Hbm映射文件产生普通的Java对象及数据表。可以参考Hibernate自带的文档《HIBERNATE - 符合Java习惯的关系数据库持久化》的第15章--《工具箱指南》一节。同样,这篇文章没有过多谈理论,只是给出了一个完整的实例加以说明。相关配置请参考上篇文章。
    #蓝梦丁丁 发表于2006-06-16 00:58:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--1. 入门实例》

    这篇文章主要谈谈Hibernate的入门开发,例子很简单,就是向数据表中添加用户名和密码。我分别使用了三种方法,一种是直接写代码,写Hbm映射文件等;一种是通过Hbm映射文件来生成代码;一种是通过代码来生成Hbm映射文件。使用了一些自动化工具,XMLBuddy是用来编辑XML文件的,JBoss Eclipse IDE是用来编写Doclet标记的。这篇文章还谈到了一些Eclipse的使用技巧,比如建立“用户库”、“生成 Getter 和 Setter”等。
    #icejava 发表于2006-06-16 13:38:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--1. 入门实例 》

    Eclipse快速上手Hibernate--1. 入门实例
    #icejava 发表于2006-06-16 13:41:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发 》

    Eclipse快速上手Hibernate--2. 利用Hbm映射文件开发
    #icejava 发表于2006-06-16 13:43:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(1) 》

    Eclipse快速上手Hibernate--4. 继承映射(1)

    #icejava 发表于2006-06-16 13:45:00  IP: 211.100.21.*
    TrackBack来自《Eclipse快速上手Hibernate--4. 继承映射(3) 》

    Eclipse快速上手Hibernate--4. 继承映射(3)
    #CJamie 发表于2006-08-29 15:47:00  IP: 211.100.21.*
    TrackBack来自《快速上手Spring--2.HelloWorld(1)》

    快速上手Spring--2.HelloWorld(1)
    #esmiles 发表于2005-04-14 12:27:00  IP: 210.83.200.*
    问一下,设置“构建路径”有什么用处?谢谢
    #javamxj 发表于2005-04-14 13:40:00  IP: 218.79.116.*
    To esmiles:
    设置“构建路径”是为了与后面文章中的build.xml相配合
    #super2 发表于2005-05-02 16:24:00  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 <
    #阿义 发表于2005-05-03 02:45:00  IP: 218.2.173.*
    可能是因为你生成的hibernate.cfg.xml文件里面数据库密码错误
    #阿义  发表于2005-05-03 05:11:00  IP: 218.2.173.*
    你把build.xml里mysql用户名密码改成自己的就应该没有问题了~
    #qinfe 发表于2005-05-17 15:38:00  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)
    #qinfen 发表于2005-05-17 15:40:00  IP: 210.75.0.*
    請你幫我指出原因
    另外請問你的QQ是多少?
    謝謝!
    #qinfen 发表于2005-05-17 15:40:00  IP: 210.75.0.*
    請你幫我指出原因
    另外請問你的QQ是多少?
    謝謝!
    #javamxj 发表于2005-05-17 17:08:00  IP: 218.79.116.*
    To qinfen:
    没有更多的信息,我也不清楚你的错误原因,hibernate.cfg.xml 应该在javamxj.hibernate包下。
    #javamxj 发表于2005-05-17 17:10:00  IP: 218.79.116.*
    我一般不用QQ,联系请用email
    #javamxj 发表于2005-05-17 17:10:00  IP: 218.79.116.*
    我一般不用QQ,联系请用email
    #jason 发表于2005-05-17 11:21:00  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.hibernat
    #jason 发表于2005-05-17 11:23:00  IP: 211.100.227.*
    上面是什么原因导致的?
    #cym 发表于2005-06-12 15:45:00  IP: 61.186.252.*
    文笔和功力都相当不错,难得的市写的清晰易懂,全部收藏,downloading..........感谢作者的无私奉献
    #cym 发表于2005-06-12 15:49:00  IP: 61.186.252.*
    不过开发hibenate的话,myeclipse的用法更简单直接。我学习ejb,可是通过你的大作,参考并获得成功。谢谢
    #Anne 发表于2005-06-23 22:43:00  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:00  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
    #吴鹏 发表于2005-09-07 15:16:00  IP: 211.100.21.*
    我很喜欢你的blog,我已加入我的blog友情链接
    您的这篇文章写的很好,不过我一步步运行下来,最后还是报错,我查遍资料,原来用到cglib这个包的时候需要把asm.jar和asm-attrs.jar包括进来,我包括进来之后就能运行了,也能出现你说的结果了。
    欢迎交流
    QQ:309880010
    Email:anewstar@gmail.com
    #popgo 发表于2005-09-15 19:00:00  IP: 211.100.21.*
    可以运行,成功!!!

    有什么事,,请加QQ群:3263131
    #popgo 发表于2005-09-15 19:00:00  IP: 211.100.21.*
    可以运行,成功!!!

    有什么事,,请加QQ群:3263131
    我的QQ:83307856
    #落秋 发表于2005-09-24 12:30:00  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:00  IP: 219.137.37.*
    感谢javamxj写的文章,写得很详细很精典,对初学者来说真是一大福气。
    #Falcon 发表于2005-11-21 10:32:00  IP: 59.42.176.*
    很好的一篇文章,简洁,易懂,这才叫入门文章
    #maomao083 发表于2005-12-05 17:48:00  IP: 210.22.158.*
    太谢谢你了,我完成了你的例子

    中间id,username 大小写有一些问题,调试后解决!

    还有大家要注意mysql登陆密码,文中设定的

    你的这篇文章给我很多信心

    要努力在IT 业继续下去

    #maomao083 发表于2005-12-05 17:48:00  IP: 210.22.158.*
    太谢谢你了,我完成了你的例子

    中间id,username 大小写有一些问题,调试后解决!

    还有大家要注意mysql登陆密码,文中设定的

    你的这篇文章给我很多信心

    要努力在IT 业继续下去

    #sd-lichangyou 发表于2005-12-08 17:26:00  IP: 218.26.163.*
    这篇刚看完,完全可以,多谢了!好文章呀
    #yhw27del 发表于2005-12-09 15:36:00  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 16:31:00  IP: 219.234.152.*
    写得非常棒,照着做了,一次OK!感谢楼主!
    #peter 发表于2006-02-12 01:37:00  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.Sco
    #小雨 发表于2006-04-10 11:30:00  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 15:40:00  IP: 222.64.106.*
    hibernate.cfg.xml不是在javamxj.hibernate包下而是和javamxj.hibernate在同一个目录.在java环境的classpath下,即上面环境的src下面.
    #任海夸 发表于2006-05-18 23:54:00  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)
    哪位能不告诉我这是什么错?
    谢谢了
    #keane 发表于2006-05-20 17:08:00  IP: 61.170.246.*
    在LIB中加入Ehcache.jar的包
    #Jonson 发表于2006-07-06 17:06:00  IP: 222.130.156.*
    ===========0==========
    Exception in thread "main" java.lang.ExceptionInInitializerError
    at jonson.Test.main(Test.java:12)
    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:95)
    ... 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
    这个是什么问题啊?着急啊!
    #啄木鸟 发表于2006-09-13 22:14:00  IP: 218.81.74.*
    jdbc:mysql://localhost:3306/HibernateTest?useUnicode=true&amp;characterEncoding=GBK 这句话中间的&amp;如果等于&符号,放在XMLBuddy编辑器中报错。改一下吧
    #F555666 发表于2007-02-08 14:06:54  IP: 59.37.4.*
    运行时报错:
    Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
    at net.sf.hibernate.cfg.Configuration.<clinit>(Configuration.java:95)
    at javamxj.hibernate.Test.main(Test.java:13)

    出错的语句是:
    SessionFactory sf = new Configuration().configure().buildSessionFactory();
    #lucky121 发表于2007-03-11 07:53:12  IP: 221.219.56.*
    不错,喜欢这样的文章。
    废话少,可操作性强。确实有利于入门。
    发表评论  


    当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
    Csdn Blog version 3.1a
    Copyright © javamxj