写一段mybatis not in的语句
时间: 2023-03-29 16:03:30 浏览: 150
以下是一个 MyBatis 中使用 not in 的示例语句:
<select id="selectUsersByAgeNotIn" resultType="User">
SELECT * FROM users WHERE age NOT IN
<foreach item="item" collection="ageList" open="(" separator="," close=")">
#{item}
</foreach>
</select>
其中,ageList 是一个 List<Integer> 类型的参数,表示不包含的年龄列表。这个语句将返回年龄不在 ageList 中的所有用户。
相关问题
写一段mybatis用于删除的 not in的语句
好的,以下是一段使用 MyBatis 进行 not in 删除的语句:
```
<delete id="deleteNotIn" parameterType="java.util.List">
DELETE FROM table_name
WHERE id NOT IN
<foreach collection="list" item="id" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
```
其中,`table_name` 是需要删除数据的表名,`id` 是该表的主键字段名。`list` 是一个 `java.util.List` 类型的参数,其中包含了需要保留的主键值。这个语句会删除表中所有主键值不在 `list` 中的数据。
希望这个回答能够帮到你!
mybatis-plus notLike
### MyBatis-Plus `notLike` 方法使用详解
#### 1. 简介
MyBatis-Plus 提供了丰富的条件构造工具来简化 SQL 查询语句的编写工作。其中,`notLike` 是用于构建模糊匹配查询的一个重要方法之一[^2]。
#### 2. 使用场景
当需要排除某些特定模式的数据记录时可以采用此操作符。比如,在用户管理模块中想要获取名字不包含 "admin" 字样的所有账户列表就可以利用该特性完成过滤[^3]。
#### 3. API 调用方式
通过继承 BaseMapper 或者自定义 Mapper 接口并引入 Wrapper 工具类(如 QueryWrapper 和 LambdaQueryWrapper),能够方便快捷地调用 notLike 函数来进行字段值的部分否定匹配检索。
#### 4. 示例代码
下面给出一段基于 Spring Boot 的 Java 应用程序片段展示如何运用 notLike 进行数据库查询:
```java
// 导入必要的包
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class UserService {
@Autowired
private UserMapper userMapper; // 假设有一个User实体对应的Mapper
public List<User> getUsersNotLikeName(String namePart){
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.notLike("name", namePart); // 设置name列不等于指定字符串部分
return userMapper.selectList(queryWrapper);
}
}
```
对于更复杂的业务逻辑可能涉及到多个字段的同时判断,则可以通过链式编程的方式继续添加其他条件表达式。
阅读全文