一. 实体类的编写规则
1.实体类里面的属性都是私有的
2. 私有属性使用公开的set和get方法操作
3.要求实体类有属性作为唯一值
4.实体类属性建议不使用基本数据类型,使用基本数据类型对应的包装类
二. Hibernate主键生成策略 : 1. native (主要使用的) 2. uuid 3. 等等
<hibernate-mapping>
<class name="com.company.User" table="user">
<id name="uid" column="did">
<!--设置数据表id增长策略-->
/*
* class 属性: 1. native 是主键自增长
2. uuid 是生成唯一的uuid值
*/
<generator class="native"></generator>
</id>
</class>
</hibernate-mapping>
注: 使用native值时, 实体类中的uid属性是 int 型
使用uuid时, 实体类中的uid属性必须是String型
三.实体类操作
- 添加操作: 调用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();
}
}
- 根据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();
}
}
- 删除操作: 先查询再删除
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使用
- Query 对象
1.使用query对象,不需要写sql语句,但是写hql语句
2.区别: 使用sql操作表和表字段,使用hql操作实体类和属性
3.查询所有hql语句: from 实体类名称
实例:
//创建Query对象
Query query = session.createQuery("from User");
//调用Query对象里面的方法得到结果
List<User> 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<User> list = criteria.list();
3.SQLQuery 对象
1.使用SQLQuery对象时,调用底层sql实现
实例:
//创建SQLQuery 对象(此对象方法都已经废弃)
SQLQuery sqlQuery = session.createSQLQuery("select * from t_user");
sqlQuery.addEntity(User.class);
List<User> list = sqlQuery.list();