Eclipse Hibernate基本配置及简单实现

使用Hibernate需要导入的一些jar包

hibernate2.jar: --------Hibernate的库,必须使用的jar包

cglib-full-2.0.2.jar --------CGLIB库,Hibernate用它来实现PO字节码的动态生成,非常核心的库,必须使用的jar包

dom4j-1.4.jar ---dom4j 是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。在IBM developerWorks上面可以找到一篇文章,对主流的Java XML API进行的性能、功能和易用性的评测,dom4j无论在那个方面都是非常出色的。这是必须使用的jar 包,Hibernate用它来读写配置文件。

odmg-3.0.jar ----ODMG是一个ORM的规范,Hibernate实现了ODMG规范,这是一个核心的库,必须使用的jar包。


commons-collections-2.1.1.jar:
Apache Commons包中的一个,包含了一些Apache开发的集合类,功能比java.util.*强大。必须使用的jar包。

commons-beanutils.jar:-----Apache Commons包中的一个,包含了一些Bean工具类类。必须使用的jar包。

 


commons-lang-1.0.1.jar -----包中的一个,包含了一些数据类型工具类,是java.lang.*的扩展。必须使用的jar包。

commons-logging-1.0.4.jar -----Apache Commons包中的一个,包含了日志功能,必须使用的jar包。

anant-1.5.3.jar -----Ant编译工具的jar包,用来编译Hibernate源代码的。如果你不准备修改和编译Hibernate源代码,那么就没有什么用,可选的jar包
ant-optional-1.5.3.jar -----Ant的一个辅助包。

c3p0-0.8.4.5.jar -----C3PO是一个数据库连接池,Hibernate可以配置为使用C3PO连接池。如果你准备用这个连接池,就需要这个jar包。

proxool-0.8.3.jar -----也是一个连接池,同上。

commons-pool-1.2.jar, commons-dbcp-1.2.1.jar
DBCP数据库连接池,Apache的Jakarta组织开发的,Tomcat4的连接池也是DBCP。

实际上Hibernate自己也实现了一个非常非常简单的数据库连接池,加上上面3个,你实际上可以在Hibernate上选择4种不同的数据库连接池,选择哪一个看个人的偏好,不过DBCP可能更通用一些。另外强调一点,如果在EJB中使用Hibernate,一定要用App Server的连接池,不要用以上4种连接池,否则容器管理事务不起作用。

connector.jar: -----JCA 规范,如果你在App Server上把Hibernate配置为Connector的话,就需要这个jar。不过实际上一般App Server肯定会带上这个包,所以实际上是多余的包。

jaas.jar -----JAAS是用来进行权限验证的,已经包含在JDK1.4里面了。所以实际上是多余的包。

jcs-1.0-dev.jar -----如果你准备在Hibernate中使用JCS的话,那么必须包括它,否则就不用。

jdbc2_0-stdext.jar: -----JDBC2.0的扩展包,一般来说数据库连接池会用上它。不过App Server都会带上,所以也是多余的。

jta.jar----JTA规范,当Hibernate使用JTA的时候需要,不过App Server都会带上,所以也是多余的。

junit-3.8.1.jar -----Junit包,当你运行Hibernate自带的测试代码的时候需要,否则就不用。

xalan-2.4.0.jar, xerces-2.4.0.jar, xml-apis.jar:
Xerces 是XML解析器,Xalan是格式化器,xml-apis实际上是JAXP。一般App Server都会带上,JDK1.4也包含了解析器,不过不是Xerces,是Crimson,效率比较差,不过Hibernate用XML只不过是读取配置文件,性能没什么紧要的,所以也是多余的。

 

1.新建一项目

2.添加hibernate配置文件:新建-》其他—》Hbernate—》Hibernate Configuration Files

mysql:

Driver Class: com.mysql.jdbc.Driver(需要加入数据库的驱动包)

Database URL: jdbc:mysql://localhost/数据库名

 

 

3.添加pojo类的映射文件:新建-》其他—》Hbernate—》Hibernate Mapping File

 

4.右击类的映射文件—》hibernate synchronizer—》synchronizer files;(添加pojo类)

 

5.右击hibernate配置文件—》hibernate synchronizer—》Add Mapping Reference;

 

hibernate.cfg.xml配置:

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
           
<hibernate-configuration>
 <session-factory>
  <!-- local connection properties -->
  <property name="hibernate.connection.url">
   jdbc:mysql://localhost/selftest
  </property>
  <property name="hibernate.connection.driver_class">
   com.mysql.jdbc.Driver
  </property>
  <property name="hibernate.connection.username">root</property>
  <property name="hibernate.connection.password">root</property>
  <!-- property name="hibernate.connection.pool_size"></property -->
  <!-- dialect for MySQL -->
  <property name="dialect">
   org.hibernate.dialect.MySQLDialect
  </property>
  <property name="hibernate.show_sql">true</property>
  <property name="hibernate.transaction.factory_class">
   org.hibernate.transaction.JDBCTransactionFactory
  </property>
  
  
  <!-- <property name="hibernate.connection.characterEncoding">utf8</property> -->
  <mapping resource="com/yss/pojo/UserInfo.hbm.xml" />
  <mapping resource="com/yss/pojo/Company.hbm.xml" />
  <mapping resource="com/yss/pojo/Employee.hbm.xml" />
 </session-factory>
</hibernate-configuration>

 

Test类:

public class UserInfoDAO {

 /**
  * @param args
  */
 public static void main(String args[]) {
  SessionFactory factory = new Configuration().configure()
    .buildSessionFactory();
  Session session = factory.openSession();
  Transaction tx = session.beginTransaction();
  try {
   UserInfo ui = new UserInfo();
   ui.setName(new String("龙") );
   ui.setPassword("1986");

   session.save(ui);
   System.out.println(((UserInfo)session.get(UserInfo.class,30)).getPassword());
   System.out.println(((UserInfo)session.load(UserInfo.class,30)).getName());
   
   tx.commit();
  } catch (Exception e) {
   System.out.println(e.getMessage());
   e.printStackTrace();
  }

 }
}

一对一映射:

company类中加入:public Set<Employee> employees=new HashSet<Employee>();

 

company映射文件加入:

<set name="employees" table="employee" cascade="all-delete-orphan" inverse="true" lazy="true">
   <key column="cid" not-null="true"></key>
   <one-to-many class="Employee"/>
  </set>
 

public  class Test{

   public static void main(String[] args) {

        SessionFactory sf=new Configuration().configure().buildSessionFactory();
       Session session=null;
       Transaction tran=null;

       try {
          session=sf.openSession();
         tran=session.beginTransaction();
   
       //插入数据
       Company com=new Company();
      com.setCname("赢时胜软件");
      com.setAddress("金运世纪大厦");
 
      session.save(com);
     Employee emp1=new Employee();
     emp1.setCid(2);
     emp1.setEname("jkjd");
     emp1.setAge(25);
     emp1.setBirthday(new Date());
     com.getEmployees().add(emp1);
    
     Employee emp2=new Employee();
     emp2.setEname("liubi");
     emp2.setAge(22);
     emp2.setBirthday(new Date());
     com.getEmployees().add(emp2);
   
   
     //删除
    //Employee emp2=new Employee();
    //emp2.setId(1);    //删除此主键存在的记录
   // emp2.setEname("121");
  // session.delete(emp2);


    session.save(com);
    tran.commit();
  } catch (HibernateException e) {
       // TODO Auto-generated catch block
       System.out.println(e.getMessage());
       e.printStackTrace();
  }

}

 jar包及实例:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hibernate Tools for eclipse 创建Hibernate Console Configuration向导有Main、Option、Classpath、Mappings、Common五个选项卡,如果你在工程已经引入了JDBC驱动则,直接点击Finish完成即可,以后在完成其他配置。 完成后,你就可以在Hibernate Configuration视图窗口看到配置项,已经链接到数据,并把你数据库的表列出来,如果在这一步你没有成功的话,请检查你是否以正确安装的Hibernate Tools和JBoos Tools这个很重要;另外如果提示找不到JDBC驱动的话,说明你工程的classpath没有JDBC驱动jar包,加载正确的驱动即可。 如果你不能看到上图所示的Hibernate Configurations窗口,说明你没有打开这个View,选择Windows-Show View-Other,然后选择Hibernate Configurations即可打开这个窗口,窗口的位置无关紧要,你喜欢放在那里就把他托过去。 下面将介绍如何使用Hibernate Code Generation来产生数据库表映射Java对象,首先要在数据库创建表,并设置号字段名和主键(主键很重要,关于主键的选择建议你使用与业务无关的ID作为主键);打开Hibernate视图找到Hibernate运行图标下的Hibernate Code Generation Configurations,如果找不到这个图标说明没有在Hibernate视图下。 配置一个新的配置项,输入配置项的名称MyHibernateCode,选择Hibernate Configuration(即已配好的Hibernate控制台配置),在Output directory输入反向代码输出目录(注意这个目录一般只需项目的源代码src),然后复选Reverse engineer from JDBC connection,在Package输入包名(你要存放到src下那个包),最后单击Setup-Create New打开Reverse engineer配置向导,选择配置存储位置(我放到了src目录下),最后选择要反向工程的表,如图; 如果你的Database schema没有项目,查看你选择Console configuration是否正确,单击下面“Refresh”应该就出来了,最后单击Finish完成返回, 然后单击Exporters选项卡,选择导出项目,这里选择了Domain code(.java) 和Hibernate XML Mappings(.hbm.xml),因为使用的JDK版本较高因此复选Use Java 5 syntax项。Refresh和Common项可不进行设置,最后单击Run运行,产生代码。 产生的代码和配置文件,如图示;代码自动产生后还需要你根据自己的业务逻辑检查一下,并按你的DAO架构完成,Hibernate Tools到这里已经帮你完成的大量编码工作。 【编辑推荐
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值