MyBatis05-特殊Sql

1MyBatis的模糊查询

例子:查询名字含有李的人
Mapper接口方法名字:

根据用户名模糊查询用户信息
    List<User> getUserByLike(@Param("userName") String userName);

Mapper映射:
使用#{}产生的问题:

<select id="getUserByLike" resultType="User">
        select * from t_user where username like '%#{userName}%'
</select>

编译后的Sql语句:

select * from t_user where username like '%?%'

解决方式1:使用${}拼接字符串

<select id="getUserByLike" resultType="User">
        select * from t_user where username like '%${userName}%'
</select>

编译后Sql语句:

select * from t_user where username like '%李%'

解决方式2:使用concat拼接字符串

<select id="getUserByLike" resultType="User">
        select * from t_user where username like concat('%',#{userName},'%')
</select>

编译后Sql语句:

select * from t_user where username like concat('%',?,'%')

解决方式3:使用双引号

<select id="getUserByLike" resultType="User">
        select * from t_user where username like "%"#{userName}"%"
</select>

编译后Sql语句:

select * from t_user where username like "%"?"%"

2MyBatis的批量操作

例子:批量删除用户信息:
接口的方法:

//批量删除
    int deleteMore (@Param("ids") String ids);

使用#{}的映射:

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

测试:
表中数据:
在这里插入图片描述

 @Test
    public void test2(){
        SqlSession sqlSession = SqlSessionUtil.getSqlSession();
        SqlMapper mapper = sqlSession.getMapper(SqlMapper.class);
        int i = mapper.deleteMore("15,16,17,18");
        System.out.println(i);
    }

测试结果:可以看到受影响的行数为0,没有删除成功
在这里插入图片描述
使用${}的映射:

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

测试结果:受影响行数为1行,成功将用户删除
在这里插入图片描述

3:MyBatis动态获取表名

我们可以在存储数据时,将数据分为多张表存储,在执行sql操作时,需要动态的选择表名。
接口中的方法:

 /*
    动态获取表名
    数据库存储数据,为了便于操作,可能将一张表拆分为多张表,所以在执行sql操作时,需要动态的附带上表名
     */
    List<User> getUserByTableName(@Param("tableName") String tableName);

使用#{}获取:

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

测试:报错,#{}会自动添加单引号,导致sql语句错误
在这里插入图片描述使用${}获取:

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

测试:查询成功
在这里插入图片描述

4:MyBatis获取自增的主键

比如我们在添加班级信息时,添加了学生信息,而学生信息中就包含了班级信息,如何获取班级的自增的id。
接口中的方法:

void insertUser(User user);

映射的文件:
useGeneratedKeys=“true”:表明当前sql使用自动递增的主键
keyProperty:将自增的主键的值赋给传输到映射文件中的参数的某个属性

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

测试;

    @Test
    public void test(){
        SqlSession sqlSession = SqlSessionUtil.getSqlSession();
        SqlMapper mapper = sqlSession.getMapper(SqlMapper.class);
        User user = new User(null, "test", "test", 3, "男", "test");
        mapper.insertUser(user);
        System.out.println(user);
    }

结果:我们可以看到输出的user存在id属性的值
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值