一、下载Hibernate包的下载

官网地址:http://hibernate.org/orm/

下载版本:hibernate-release-4.3.11.Final

二、Hibernate jar包介绍

包名

用途

hibernate-core-4.3.11.Final.jar Hibernate核心包
antlr-2.7.7.jar Hibernate利用它实现从HQL到SQL的转换
dom4j-1.6.1.jar 解析XML配置文件和XML映射文件
hibernate-commons-annotations-4.0.5.Final.jar Hibernate注解包
hibernate-jpa-2.1-api-1.0.0.Final.jar JPA2.1接口库
jandex-1.1.0.Final.jar 用来索引Anotation的
javassist-3.18.1-GA.jar Hibernate用它来实现PO字节码的动态生成
jboss-logging-3.1.3.GA.jar 日志服务通用库
jboss-logging-annotations-1.2.0.Beta1.jar 实现带注释的借口的具体实现类
jboss-transaction-api_1.2_spec-1.0.0.Final.jar JTA规范包

三、Hibernate核心配置文件

hibernate.cfg.xml:是Hibernate的核心配置文件,主要功能有:

  • 配置数据库连接的各种属性
  • 注册对象关系映射文件。
  • 开发阶段的调试信息。
  • 运行时的日志信息。

    四、搭建Hibernate开发环境

  • 新建javaproject工程。
  • 新建libs文件夹,将hibernate中required的所有文件复制到java工程的libs文件夹中,将所连接的数据库驱动包也复制到文件夹下。
  • 将hibernate中project下etc下的hibernate.cfg.xml和log4j.properties复制到SRC根目录下。

  • 五、测试代码

    1、 创建学生表

    hibernate.cfg.xml配置文件

    <!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration>
    <session-factory> <!-- 配置数据库连接 -->
    <!-- Hibernate的方言:生成SQL语句的规则 -->
    <property name="hibernate.dialect">
    org.hibernate.dialect.MySQL5Dialect
    </property>
    <!-- 数据库驱动包 -->
    <property name="hibernate.connection.driver_class">
    com.mysql.jdbc.Driver
    </property>
    <!-- 数据库URL地址 -->
    <property name="hibernate.connection.url">
    jdbc:mysql://127.0.0.1:3306/test
    </property>
    <!-- 用户名 -->
    <property name="hibernate.connection.username">root</property>
    <!-- 密码 -->
    <property name="hibernate.connection.password">root</property> <!-- 是否输出SQL语句 -->
    <property name="show_sql">true</property>
    <!-- 是否格式化SQL语句 -->
    <property name="format_sql">true</property> <!-- 如果对象有更新则重新生成SQL表
    create:重新生成
    update:更新
    -->
    <property name="hbm2ddl.auto">update</property> <!-- 注册实体映射文件 -->
    <mapping resource="com/lxit/entity/Student.hbm.xml" />
    </session-factory>
    </hibernate-configuration>

    2、学生类

    package com.lxit.entity;
    
    import java.io.Serializable;
    
    public class Student implements Serializable{
    
        public Student(){}
    /**
    *
    */
    private static final long serialVersionUID = 1L; public Student(String loginId, String loginPwd, String realName, String phone, String address, String email) {
    super();
    this.loginId = loginId;
    this.loginPwd = loginPwd;
    this.realName = realName;
    this.phone = phone;
    this.address = address;
    this.email = email;
    }
    private String loginId;
    private String loginPwd;
    private String realName;
    private String phone;
    private String address;
    private String email; public String getLoginId() {
    return loginId;
    }
    public void setLoginId(String loginId) {
    this.loginId = loginId;
    }
    public String getLoginPwd() {
    return loginPwd;
    }
    public void setLoginPwd(String loginPwd) {
    this.loginPwd = loginPwd;
    }
    public String getRealName() {
    return realName;
    }
    public void setRealName(String realName) {
    this.realName = realName;
    }
    public String getPhone() {
    return phone;
    }
    public void setPhone(String phone) {
    this.phone = phone;
    }
    public String getAddress() {
    return address;
    }
    public void setAddress(String address) {
    this.address = address;
    }
    public String getEmail() {
    return email;
    }
    public void setEmail(String email) {
    this.email = email;
    }
    public static long getSerialversionuid() {
    return serialVersionUID;
    } }

    3、实体映射文件

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE hibernate-mapping PUBLIC
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping>
    <class name="com.lxit.entity.Student" table="Student"> <id name="loginId" column="loginId">
    <generator class="assigned"></generator>
    </id> <property name="loginPwd" column="loginPwd"></property>
    <property name="realName" column="realName"></property>
    <property name="phone" column="phone"></property>
    <property name="address" column="address"></property>
    <property name="email" column="email"></property> </class>
    </hibernate-mapping>

    4、测试类

    package com.lxit.test;
    
    import org.hibernate.Session;
    import org.hibernate.SessionFactory;
    import org.hibernate.Transaction;
    import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
    import org.hibernate.cfg.Configuration;
    import org.hibernate.service.ServiceRegistry;
    import org.hibernate.tool.hbm2ddl.SchemaExport;
    import org.junit.Test; import com.lxit.entity.Student; public class StudentTest { //@Test
    public void createTable(){
    Configuration cfg = new Configuration().configure();
    SchemaExport export = new SchemaExport(cfg);
    export.create(true, true); //创建表,在控制台输出SQL语句
    } @Test
    public void add(){
    Configuration cfg = new Configuration().configure(); //hibernate3.0版本创建sessionFactory的方法
    //SessionFactory factory = cfg.buildSessionFactory(); //hibernate4.0版本创建sessionFactory方法
    StandardServiceRegistryBuilder ssrb = new StandardServiceRegistryBuilder().applySettings(cfg.getProperties());
    ServiceRegistry sr = ssrb.build();
    SessionFactory factory = cfg.buildSessionFactory(sr);
    Session session = factory.openSession();
    Transaction tran = session.beginTransaction(); Student stu = new Student("zhangsan", "123123", "张三", "12345678901", "广东深圳", "zhangsan@163.com"); try {
    session.save(stu);
    tran.commit();
    System.out.println("保存成功!");
    } catch (Exception e) {
    tran.rollback();
    }finally{
    session.close();
    factory.close();
    }
    }
    }

    Hibernate开发环境搭建的更多相关文章

    1. 手把手在MyEclipse中搭建Hibernate开发环境

      (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/53414303冷血之心的博客) 在MyEclipse中如何搭建Hib ...

    2. spring mvc4.1.6 + spring4.1.6 + hibernate4.3.11 + mysql5.5.25 开发环境搭建及相关说明

      一.准备工作 开始之前,先参考上一篇: struts2.3.24 + spring4.1.6 + hibernate4.3.11 + mysql5.5.25 开发环境搭建及相关说明 struts2.3 ...

    3. Java 开发环境搭建

      找到一篇很不錯的Java開發環境搭建的博客, 原文地址為:http://www.cnblogs.com/bribe/p/3377008.html Java 开发环境搭建 一.开发工具获取 1.开发工具 ...

    4. [Hibernate 1]Hibernate的环境搭建

      一.Hibernate是什么 直接使用JDBC操作数据库的步骤很繁琐,JDBC操作的是关系型数据库,而我们用JAVA开发程序,则使用面向对象的思想.Hibernate正是在这两种不同的模型之间建立关联 ...

    5. Java基本开发环境搭建(适合第一次使用)

      Java基本开发环境搭建(适合第一次使用) 编写人:cc 阿爸 2013-10-17 一.开发工具获取 1.开发工具包JDK l  下载地址: 到ORACLE公司官方网站(http://www.ora ...

    6. 工作流--JBPM简介及开发环境搭建

      一. 工作流简介 项目中不断的接触工作流,点点滴滴积累了一些,下面把一些学习到的东西整理记录下来. 工作流一般的适用场景:公文流转.行政审批.订单处理.产品研发.制造过程等.用专业一点的语言来描述工作 ...

    7. Spring框架入门之开发环境搭建(MyEclipse2017平台)

      基于MyEclipse2017平台搭建Spring开发环境,这里MyEclipse已将Spring集成好了,我们只需要做一简单配置即可 一.环境配置 OS:Windows7 64位 IDE工具:MyE ...

    8. 1.mybatis实战教程mybatis in action之一开发环境搭建

      转自:https://www.cnblogs.com/shanheyongmu/p/5652471.html 什么是mybatis MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框 ...

    9. Flask框架的学习与实战(一):开发环境搭建

      Flask是一个使用 Python 编写的轻量级 Web 应用框架.其 WSGI 工具箱采用 Werkzeug ,模板引擎则使用 Jinja2.很多功能的实现都参考了django框架.由于项目需要,在 ...

    随机推荐

    1. POJ 1797 Heavy Transportation 【最大生成树的最小边/最小瓶颈树】

      Background Hugo Heavy is happy. After the breakdown of the Cargolifter project he can now expand bus ...

    2. POJ 1258 + POJ 1287 【最小生成树裸题/矩阵建图】

      Farmer John has been elected mayor of his town! One of his campaign promises was to bring internet c ...

    3. python3 2017.3.19

      今天弄了一个晚上没弄出来一个小东西,只弄出来了写追加,而且还是笨方法,起码死不掉那种. global log 127.0.0.1 local2 daemon maxconn 256 log 127.0 ...

    4. 读书笔记(javascript语言精粹)

      1. 注释: 在js中,/**/为块注释,//为行注释:但块注释在有些情况下是不安全的.如: /* var rm_a = /a*/.match(s); */ 上面的注释导致了一个语法错误.所以,建议避 ...

    5. 【java】线程安全的整型类AtomicInteger

      一.遇见AtomicInteger 在看项目代码的时候看到这个类,发现其功能很简单,就是一个整型变量的类型,出于好奇看了其类定义. 该类位于java.util.concurrent.atomic下,在 ...

    6. AGC 026 C - String Coloring

      题面在这里! 比较简单的折半搜索,推一下hash函数,要求正反最后相等就行了. #include<bits/stdc++.h> #define ll unsigned long long ...

    7. 【树形dp】Distance in Tree

      [CF161.D] Distance in Tree time limit per test 3 seconds memory limit per test 512 megabytes A tree  ...

    8. 【数论】nefu118 n!后面有多少个0

      就是求n!有多少个因子2和因子5,并在这两者中取较小者.因为必须要一个2和一个5才能拼出1个10. 显然2的数量多于5,因此只需要求n!有多少个因子5即可. n!中素因子p的个数= [n/p]+[n/ ...

    9. 【二分答案+智障的字符串hash】BZOJ2946-[Poi2000]公共串(Ranklist倒一达成!!!!!)【含hash知识点】

      [题目大意] 给出几个由小写字母构成的单词,求它们最长的公共子串的长度. [字符串hash的小笔记] hash[i]=(hash[i-1]*p+idx(s[i]))%mod,idx为映射值,一般a.. ...

    10. 看看如何解决“SQL Server只能使用Windows身份登录,不能使用sa等Sql server身份进行登录”的问题

      今天安装Sql Server之后,出现SQL Server只能使用Windows身份登录,不能使用sa等Sql server身份进行登录的问题是由于sql server只设置了Windows身份验证, ...