mybatis-plus的or()为啥拼接出来是and? 为啥不是or 怎样让sql拼成or
时间: 2024-05-05 13:15:28 浏览: 109
mybatis-plus的or()方法默认拼接出来的条件是使用"AND"连接的,因为它是基于MyBatis的Criteria API实现的,而MyBatis中的or方法也是这样实现的。
如果要让拼接出来的条件使用"OR"连接,可以使用LambdaQueryWrapper的or方法,并设置参数为true,例如:
```
LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(User::getAge, 20)
.or(true)
.eq(User::getName, "Tom");
```
这样就能够拼接出使用"OR"连接的条件了。
相关问题
mybatis-plus 拼接sql
Mybatis-plus是Mybatis的增强工具,提供了更加方便、快速的开发体验。在实际开发中,我们有时需要动态地拼接SQL,Mybatis-plus为我们提供了一些丰富的API来进行SQL拼接。
1. Wrapper
Wrapper是Mybatis-plus提供的一个用于拼接SQL语句的抽象类。它提供了一系列的查询条件构造方法,比如eq、ne、like等等。使用Wrapper可以有效地避免手写SQL语句时因为类型转换等问题导致的不安全因素,也可以避免SQL注入。
2. LambdaQueryWrapper
LambdaQueryWrapper是Wrapper的一个特殊子类,它采用lambda表达式的形式,更加方便地进行拼接。使用LambdaQueryWrapper可以在Java代码中写出和SQL一样的查询条件,比如:
LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(User::getName, "张三");
List<User> userList = userService.list(wrapper);
上述代码中,我们使用LambdaQueryWrapper构造了一个查询条件,查询名字为“张三”的用户。可以看到,使用LambdaQueryWrapper的方式非常直观,更加方便。
3. UpdateWrapper
UpdateWrapper是用于构造更新操作的Wrapper子类。使用UpdateWrapper可以方便地设置更新的字段和更新条件,比如:
UpdateWrapper<User> wrapper = new UpdateWrapper<>();
wrapper.set("name", "张三");
wrapper.eq("id", 1);
userService.update(wrapper);
上述代码中,我们使用UpdateWrapper构造了一个更新条件,更新名字为“张三”的用户,条件是ID为1。
4. QueryBuilder
QueryBuilder是Mybatis-plus提供的一个动态SQL构造器,它可以将多个SQL片段拼接成一条完整的SQL语句。使用QueryBuilder可以更加方便地构建复杂的查询语句。比如:
String sql = new QueryBuilder()
.select("id", "name", "age")
.from("user")
.where("age > 18")
.orderBy("id DESC")
.build();
List<Map<String, Object>> userList = jdbcTemplate.queryForList(sql);
上述代码中,我们使用QueryBuilder构建了一个查询语句,查询所有年龄大于18的用户,按照ID降序排列。
总之,Mybatis-plus提供了众多API来拼接SQL,不管是Wrapper、LambdaQueryWrapper、UpdateWrapper还是QueryBuilder,都可以方便地满足我们的各种SQL拼接需求。开发者可以根据具体情况选择不同的API进行使用,提高代码的开发效率和可读性。
mybatis-plus apply拼接sql
Mybatis-Plus的apply方法可以用于拼接SQL语句。它可以将一段SQL语句作为参数传入,然后将其拼接到主SQL语句中。使用apply方法可以方便地实现复杂的SQL查询,例如多表关联查询、子查询等。在使用apply方法时,需要注意SQL注入的问题,应该使用参数化查询来避免注入攻击。
阅读全文
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)