QueryWrapper自定义sql
时间: 2023-10-14 11:04:03 浏览: 77
QueryWrapper是MyBatis-Plus提供的一个查询构造器,可以方便地进行复杂的查询操作。如果需要自定义SQL语句,可以使用QueryWrapper的lambda表达式或者Wrapper的方法来构造SQL语句。例如:
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.select("id", "name", "age").eq("age", 18).orderByDesc("id");
List<User> userList = userMapper.selectList(wrapper);
这段代码中,我们使用QueryWrapper构造了一个查询条件,查询id、name、age三个字段,其中age等于18,按照id倒序排序。最后使用userMapper的selectList方法执行查询操作,返回符合条件的User列表。
如果需要自定义更复杂的SQL语句,可以使用Wrapper的方法来构造SQL语句。例如:
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.apply("date_format(create_time,'%Y-%m-%d') = '2021-01-01'");
这段代码中,我们使用QueryWrapper构造了一个查询条件,查询create_time字段等于2021-01-01的记录。其中apply方法可以接收一个字符串参数,该参数就是自定义的SQL语句。最后使用userMapper的selectList方法执行查询操作,返回符合条件的User列表。
总之,QueryWrapper提供了丰富的方法来构造SQL语句,可以满足各种复杂的查询需求。