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对象:

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;
}
}

Employee.hbm.xml 对象的映射










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



com.mysql.jdbc.Driver
jdbc:mysql:///java_test
root
root

org.hibernate.dialect.MySQL5Dialect


true

true

update


二.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);// 删除字段
  • 数据查询:
    • 主健查询:

      Employee emp = (Employee) session.get(Employee.class,5); // 主健查询
      Employee emp = (Employee) session.load(Employee.class, 2); // 主健查询,支持懒加载
  • HQL查询:

    Query query = session.createQuery("from Employee as e where e.empName = :name");// 区分大小写
    query.setString("name", "Sean");
    List list = query.list();
  • Criteria查询:
    也叫完全面向对象的查询

    Criteria criteria = session.createCriteria(Employee.class);
    criteria.add(Restrictions.eq("empName", "Sean"));
    List list = criteria.list();
  • 本地SQL查询:
    对于复杂的查询,或者上面的方式满足不了,就使用本地Sql查询

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

三.hibernate配置

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

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


映射配置




    
    
        
         
    
    
    
    
    

你可能感兴趣的:(hibernate学习笔记)