hibernate学习笔记

一.hibernate环境的搭建

1.引入jar包

核心包:
hibernate3.jar
required:
antlr-2.7.6.jar
commons-collections-3.1.jar
dom4j-1.6.1.jar
javassist-3.12.0.GA.jar
required/jta-1.1.jar
slf4j-api-1.6.1.jar
jpa:
hibernate-jpa-2.0-api-1.0.0.Final.jar
数据库驱动:
mysql-connector-java-5.1.39-bin.jar

2.写对象以及对象的映射

Employee.java对象:
<code>
public class Employee {
private int empId;
private String empName;
private Date workDate;
public int getEmpId() {
return empId;
}
public void setEmpId(int empId) {
this.empId = empId;
}
public String getEmpName() {
return empName;
}
public void setEmpName(String empName) {
this.empName = empName;
}
public Date getWorkDate() {
return workDate;
}
public void setWorkDate(Date workDate) {
this.workDate = workDate;
}
}</code>

Employee.hbm.xml 对象的映射
<code><hibernate-mapping package="com.ycTime.a_hello">
<class name="Employee" table="employee">

<id name="empId" column="id">
<generator class="native"/>
</id>

<property name="empName" column="name"></property>
<property name="workDate" column="workDate"></property>
</class>
</hibernate-mapping></code>

src/hibernate.cfg.xml(数据库连接配置)

<code>

<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///java_test</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>

<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>


<property name="hibernate.show_sql">true</property>

<property name="hibernate.format_sql">true</property>

<property name="hibernate.hbm2ddl.auto">update</property>

<mapping resource="com/ycTime/a_hello/Employee.hbm.xml"/>
</code>

二.hibernateAPI

// 获取加载配置文件的管理类对象
Configuration config = new Configuration();
// 默认加载src/hibernate.cfg.xml文件
config.configure();
// 创建session的工厂对象
SessionFactory sf = config.buildSessionFactory();
// 创建session(代表一个会话,与数据库连接的会话)
Session session = sf.openSession();
Session session = sf.getCurrentSession();
两个都可以获得session,上面的是创建session,下面的是创建或获取session
session对象维护了一次连接,代表了与数据库的会话
// 开启事务
Transaction tx = session.beginTransaction();
hibernate要求所有与数据库的操作,都必须在事务的环境
// 保存到数据库
session.save(emp);
// 提交事务
tx.commit();
// 关闭会话
session.close();


  • 对数据库的操作:
 session.save(emp);// 保存到数据库 
 session.update(emp);// 更新数据
 session.saveOrUpdate(emp);// 保存或更新数据,没有设置主健,执行保存;设置主健,执行更新;主健不存在,报错。
session.delete(emp);// 删除字段
  • 数据查询:
    • 主健查询:
      <code>
      Employee emp = (Employee) session.get(Employee.class,5); // 主健查询
      Employee emp = (Employee) session.load(Employee.class, 2); // 主健查询,支持懒加载</code>
  • HQL查询:
    <code>
    Query query = session.createQuery("from Employee as e where e.empName = :name");// 区分大小写
    query.setString("name", "Sean");
    List<Employee> list = query.list();</code>
  • Criteria查询:
    也叫完全面向对象的查询
    <code>
    Criteria criteria = session.createCriteria(Employee.class);
    criteria.add(Restrictions.eq("empName", "Sean"));
    List<Employee> list = criteria.list();</code>
  • 本地SQL查询:
    对于复杂的查询,或者上面的方式满足不了,就使用本地Sql查询

    <code>SQLQuery query = session.createSQLQuery("select * from employee").addEntity(Employee.class);
    List<Employee> list = query.list();</code>

三.hibernate配置

主配置文件的配置
自动建表
hibernate.hbm2ddl.auto create-drop
每次在创建sessionfatory时创建表,每次关闭sessionfatory时删除表
hibernate.hbm2ddl.auto create
每次创建表之前先把表删除

hibernate.hbm2ddl.auto update
(最常使用)有表就执行更新,没表就先创建表再执行更新
hibernate.hbm2ddl.auto validate
(生产环境使用)验证,当映射文件和数据库配置不一致时报错


映射配置

<code>

<!-- 
    class 映射一个对象的类
        name        指定要映射的对象的类名
        table       指定对象对应的表(不写也行,默认与对象name一致)
 -->
<class name="Employee" table="worker" >
    <!-- 主键 ,映射-->
    <id name="empId" column="id" >
        <!-- 
        主健的生成策略
            identity    自增长(适用于MySQL,db2)
            native      自增长(根据底层数据库自增长的方式来选择identity或者sequence)
            sequence    自增长(序列),oracle中的自增长策略
            increment   会有并发访问问题,一般在集群环境下使用
            assigned    指定策略为手动指定主健的值
            uuid        指定uuid随即生成的唯一的值
            foreign     外键的方式
         -->
        <generator class="native"/> 
    </id>
    <!-- 
        非主键,映射
        property 表的一列
            name        指定对象的属性名称
            column      对象属性对应的表的字段名称,不写默认与对象name一样 
            length      字段长度
            type        指定表的字段的类型,如果不指定会匹配属性(String,  Date)的类型
                java类型:         必须写全名
                hibernate类型:        直接写就行,都是小写
     -->
    <property name="empName" column="name" length="15" ></property>
    <!-- 如果列名称是数据库关键字,就用`或者改名  -->
    <property name="workDate" column="workDate"></property>
</class>

</hibernate-mapping></code>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容