Java:hibernate框架 (2)

一. 实体类的编写规则

1.实体类里面的属性都是私有的

2. 私有属性使用公开的set和get方法操作

3.要求实体类有属性作为唯一值

4.实体类属性建议不使用基本数据类型,使用基本数据类型对应的包装类

二. Hibernate主键生成策略 : 1. native (主要使用的) 2. uuid 3. 等等


    
        
            
/*
  *  class 属性:  1. native 是主键自增长
                           2. uuid 是生成唯一的uuid值
  */
            
        
    


注:  使用native值时, 实体类中的uid属性是 int 型
     使用uuid时, 实体类中的uid属性必须是String型

三.实体类操作

  1. 添加操作: 调用session里面的save方法实现;
public void AddTest(){
    SessionFactory sessionFactory =null;
    Session session = null;
    Transaction tx = null;
    try {
        // 加载配置文件
        Configuration cfg = new Configuration();
        cfg.configure();
        // 创建SessionFactory对象
        sessionFactory = cfg.buildSessionFactory();
        // 创建Session对象
        session = sessionFactory.openSession();
                tx = session.beginTransaction();  //开启事务

                // 添加操作
                User user = new User();
                user.setUsername("xiaoMing");
                user.setPassword("123456");
                user.setAddress("塔上小学");
                session.save(user);  //添加数据的方法

                tx.commit();  // 关闭事务
              
            }catch (Exception e){
                //出现异常的话,做回滚操作 
                tx.rollback();
                    }finally {
                session.close();  
                sessionFactory.close(); 
           }
        }
  1. 根据id做查询操作: 调用session的get方法;
public void SearchTest(){
    SessionFactory sessionFactory =null;
    Session session = null;
    Transaction tx = null;
    try {
        Configuration cfg = new Configuration();
        cfg.configure();
        sessionFactory = cfg.buildSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();  //开启事务
       /**
         * 查询操作
         *
         * 使用get方法做查询操作: 参数1: 实体类的Class  参数2: id值
         */
        session.get(User.class,1);
        tx.commit();
        session.close();
        sessionFactory.close();
    }catch (Exception e){
        //出现异常的话,做回滚操作
        tx.rollback();
    }finally {
        session.close();
        sessionFactory.close();
    }
}

3.修改操作: 先查询,再修改值;

public void UpdateTest(){
    SessionFactory sessionFactory =null;
    Session session = null;
    Transaction tx = null;
    try {
        Configuration cfg = new Configuration();
        cfg.configure();
        sessionFactory = cfg.buildSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();  //开启事务
      /**
       * 修改操作
       *
       * 使用update方法做查询操作
       */
        User user = session.get(User.class,1);  //查询
        user.setPassword("xiaoHong"); //使用set方法修改
        session.update(user);  // 更新数据
                                                          
        tx.commit();
        session.close();
        sessionFactory.close();
    }catch (Exception e){
        //出现异常的话,做回滚操作
        tx.rollback();
    }finally {
        session.close();
        sessionFactory.close();
    }
}
  1. 删除操作: 先查询再删除
public void DeleteTest(){
    SessionFactory sessionFactory =null;
    Session session = null;
    Transaction tx = null;
    try {
        Configuration cfg = new Configuration();
        cfg.configure();
        sessionFactory = cfg.buildSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();  //开启事务
      /**
       * 修改操作
       *
       * 使用update方法做查询操作
       */
        User user = session.get(User.class,1);  //查询
        session.delete(user);  // 更新数据
                                                          
        tx.commit();
        session.close();
        sessionFactory.close();
    }catch (Exception e){
        //出现异常的话,做回滚操作
        tx.rollback();
    }finally {
        session.close();
        sessionFactory.close();
    }
}

四.实体类对象状态

1. 瞬时态: 对象里面没有id值,对象与session没有关联

2.持久态:  对象里面有id值,对象与session关联

3.托管态: 对象有id值,对象与session 没有关联

五. Hibernate的API使用

  1. Query 对象
1.使用query对象,不需要写sql语句,但是写hql语句
2.区别: 使用sql操作表和表字段,使用hql操作实体类和属性
3.查询所有hql语句:  from 实体类名称

实例:

//创建Query对象
Query query = session.createQuery("from User");
//调用Query对象里面的方法得到结果
List list = query.list();
//遍历Listfor (User user :
        list) {
    System.out.println(user);
}

2.Criteria 对象

1. 使用这个对象进行查询操作时不需要写语句,直接调方法实现
2.实现过程:  (1)创建criteria  对象
            (2) 调用对象里面的方法得到结果

实例:

//创建Criteria对象
Criteria criteria = session.createCriteria(User.class);  (此方法官方已废弃)
 List list = criteria.list();

3.SQLQuery 对象

1.使用SQLQuery对象时,调用底层sql实现

实例:

//创建SQLQuery 对象(此对象方法都已经废弃)
 SQLQuery sqlQuery = session.createSQLQuery("select * from t_user");
 sqlQuery.addEntity(User.class);
  List list = sqlQuery.list();

你可能感兴趣的:(Java:hibernate框架 (2))