Mybatis(四)特殊SQL的查询:模糊查询、批量删除、动态设置表明、添加功能获取自增的主键

实体类:

数据库:

1、模糊查询

方案一:

不适用#{ },'%?%' 问号是属于字符串的一部分 不会被解析成占位符,会被当作是我们字符串的一部分来解析,所以我们执行的语句中找不到占位符,但是我们却为占位符进行了赋值,所以说就会报错。

我们使用{ } ,将#{}替换成{ }

sql 复制代码
这个不适用:
// select * from t_user where username like '%#{username}%'


select * from t_user where username like '%${username}%'

方案二:

使用字符串拼接的方法

sql 复制代码
select * from t_user where username like concat('%',#{username},'%')

方案三:

最常用的方式

sql 复制代码
select * from t_user where username like "%"#{username}"%"

2、批量删除

#{ } 在sql语句中被解析之后本身就会加上一个单引号 ' '

表中的 字符串 日期 字段名 都可以加单引号

不可以使用#{} 需要使用${ }

java 复制代码
/**
* 批量删除
*/
    int deleteMore(@Param("ids") String ids);

<delete id="deleteMore">
        delete from t_user where id in(${ids})
    </delete>

3、动态设置表明

使用${ }

#{ } 还是不使适用,会产生 ' ' ,动态设置表名的时候不可以带 ' '

java 复制代码
List<User> getUserByTableName(@Param("tableName") String tableName);

<select id="getUserByTableName" resultType="User">
        select * from #{tableName}
    </select>

4、添加功能获取自增的主键

java 复制代码
void insertUser(User user);


<insert id="insertUser" useGeneratedKeys="true" keyProperty="id">
        insert into t_user values(null,#{username},#{password},#{age},#{sex},#{email})
</insert>

<!--    使用自动递增的主键  获取的主键不能通过返回值进行获取-->
<!--    当我们执行完添加操作之后,user中的id属性就有值了-->
<!--    useGeneratedKeys:设置当前标签中的sql使用了自增的主键
        keyProperty: 将自增的主键的值赋值给传书到映射文件中参数的某个属性
        -->
java 复制代码
//测试代码   
 @Test
    public void testGetUserByLike1(){
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        SQLMapper mapper = sqlSession.getMapper(SQLMapper.class);
        User user = new User(null,"asdff","456789",14,"男","asdf.com");
        mapper.insertUser(user);

    }
相关推荐
Tatakai2515 小时前
Mybatis Plus分页查询返回total为0问题
java·spring·bug·mybatis
A_cot16 小时前
Redis 的三个并发问题及解决方案(面试题)
java·开发语言·数据库·redis·mybatis
晚睡早起₍˄·͈༝·͈˄*₎◞ ̑̑17 小时前
苍穹外卖学习笔记(七)
java·windows·笔记·学习·mybatis
二十雨辰19 小时前
[苍穹外卖]-12Apache POI入门与实战
java·spring boot·mybatis
Amagi.21 小时前
Redis的内存淘汰策略
数据库·redis·mybatis
执键行天涯1 天前
【经验帖】JAVA中同方法,两次调用Mybatis,一次更新,一次查询,同一事务,第一次修改对第二次的可见性如何
java·数据库·mybatis
工业甲酰苯胺1 天前
Spring Boot 整合 MyBatis 的详细步骤(两种方式)
spring boot·后端·mybatis
ggdpzhk1 天前
Mybatis 快速入门(maven)
oracle·maven·mybatis
Java小白笔记2 天前
关于使用Mybatis-Plus 自动填充功能失效问题
spring boot·后端·mybatis
计算机学姐2 天前
基于SpringBoot+Vue的篮球馆会员信息管理系统
java·vue.js·spring boot·后端·mysql·spring·mybatis