Java学习记录——createCriteria()

一、简介

createCriteria()Hibernate MyBatis 等持久层框架中常用的方法,用于构建数据库查询的条件。具体来说,它通常用于生成查询条件对象,允许开发者以面向对象的方式动态构建 SQL 查询

二、使用 createCriteria() 的场景

在使用 ORM(对象关系映射)框架时,createCriteria() 方法允许你通过代码来定义查询条件,而不是写死在 SQL 语句中。这种方法提供了更大的灵活性,尤其是在动态生成查询条件时。

三、Hibernate 示例

在 Hibernate 中,createCriteria() 是 Session 对象的方法,用于创建一个 Criteria 对象,这个对象代表数据库查询条件。

Session session = sessionFactory.openSession(); 
Criteria criteria = session.createCriteria(Employee.class); 
criteria.add(Restrictions.eq("department", "IT")); 
criteria.add(Restrictions.gt("salary", 50000));
List results = criteria.list();

在这个例子中,createCriteria(Employee.class) 创建了一个查询对象,用于从 Employee 表中查找数据。
add(Restrictions.eq(“department”, “IT”)) 和 add(Restrictions.gt(“salary”, 50000)) 是查询条件,表示查询 IT 部门中薪资大于 50000 的员工。

四、MyBatis 示例

在 MyBatis 中,createCriteria() 通常是由 MyBatis Generator 生成的 Mapper 类使用,目的是用于构建动态的 SQL 查询。例如:

EmployeeExample example = new EmployeeExample();
EmployeeExample.Criteria criteria = example.createCriteria(); 
criteria.andDepartmentEqualTo("IT"); 
criteria.andSalaryGreaterThan(50000);
List<Employee> results = employeeMapper.selectByExample(example);

这里,createCriteria() 方法用于创建一个 Criteria 对象,该对象可以用于添加查询条件。
然后,调用 employeeMapper.selectByExample(example) 方法来执行查询。

> andEqualTo 方法

  • 介绍:
    andEqualTo 方法通常出现在 MyBatis Generator 自动生成的 Criteria 类中,用于构建 SQL 查询的条件。它表示某个字段与指定的值相等的条件,用来生成 SQL 语句中的 WHERE 子句。例如,criteria.andEqualTo(“field”, value) 会生成类似于 SQL 中 WHERE field = value 的条件。

  • 和 createCriteria() 的关系:
    createCriteria():这个方法用于创建一个新的 Criteria 对象,代表一组查询条件。你可以在这个 Criteria 对象上添加各种条件,例如使用 andEqualTo 来指定字段的等于条件。

示例一:

假设我们有一个数据库表 Employee,其中有一个字段 department。我们想要查询所有属于 IT 部门的员工。

EmployeeExample example = new EmployeeExample();
EmployeeExample.Criteria criteria = example.createCriteria();
criteria.andDepartmentEqualTo("IT");
List<Employee> results = employeeMapper.selectByExample(example);

在这个例子中:

  • createCriteria() 创建了一个 Criteria 对象。
  • andDepartmentEqualTo(“IT”) 添加了一个查询条件,表示查询 department 字段等于 “IT” 的记录。

上面的代码将生成类似以下的 SQL 查询:

SELECT * FROM Employee WHERE department = 'IT';

示例二:

andEqualTo("countingDateNumber", date)
  • countingDateNumber:这是数据库表中的一个字段名。
  • date:这是与字段 countingDateNumber 进行比较的值。

这行代码表示生成的 SQL 查询将包含一个条件,要求 countingDateNumber 字段的值必须等于 date 的值。
等价于 SQL 中的:

WHERE countingDateNumber = [date]

五、总结

  • Hibernate:createCriteria() 用于创建一个 Criteria 对象,帮助构建查询条件并执行查询。
  • MyBatis:createCriteria() 通常用于生成查询条件对象,并与动态 SQL 生成结合使用。

它的主要好处是允许你在代码中以更灵活和可维护的方式定义查询条件,而无需直接编写复杂的 SQL。

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值