MyBatis六:特殊SQL语句的执行

特殊SQL语句的执行

引入
  1. MyBatis获取参数有两种方式:其中 #{ }特点是会自动添加单引号,适用于占位符填充,但是这种自动添加单引号的特点并不适用于某些SQL语句,故需要使用${ }来直接传输字符串
一、模糊查询
  1. mapper接口
    public interface SelectMapper {
        @MapKey("id")
        Map<String,Object> likeSelect(@Param("keyString") String keyStr);
    }
    
  2. mapper映射文件
    <mapper>
        <select id="likeSelect" resultType="map">
            select * from t_user where username like "%"#{keyString}"%"
        </select>
    </mapper>
    
    <!-- 其它两种写法
    	select * from t_user where username like ‘%${keyString}%’
    	select * from t_user where username like concat("%",#{keyString},"%")
    -->
    
  3. 测试
    @Test
    public void likeSelectTest() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
        Map<String, Object> map = mapper.likeSelect("admin");
        System.out.println(map);
    }
    
二、批量删除
  1. mapper接口
    public interface SelectMapper {
        void deleteMany(@Param("ids") String ids);
    }
    
  2. mapper映射文件

    不是使用#{ids},是因为#{}会自动将获取的参数加上一对单引号,in (‘2,3’)这种语法是不正确的

    <delete id="deleteMany">
        delete from t_user where id in (${ids})
    </delete>
    
  3. 测试
     @Test
    public void deleteManyTest() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
        mapper.deleteMany("2,3");
    }
    
三、动态设置表名
  1. 实际情况

    在实际的生产中,如果一张表中的数据过多,会影响MySQL的性能,故会将这张表水平拆分成多张表,所以在查询一条数据时,就需要在几张表中共同查询,故查询语句中的表名是动态的

  2. mapper接口
    public interface SelectMapper {
        @MapKey("id")
        Map<String,Object> getUserByTableName(@Param("tableName") String tableName);
    }
    
  3. mapper映射文件
    <select id="getUserByTableName" resultType="map">
        select * from ${tableName}
    </select>
    
  4. 测试
    @Test
    public void getUserByTableNameTest() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
        Map<String, Object> map = mapper.getUserByTableName("t_user");
        System.out.println(map);
    }
    
四、添加功能中:获取自增的主键
  1. 实际情况

    在普通的添加功能,自增列的值被设为null,执行过程中不显示该列的值,故无法执行一些涉及到该列的操作

  2. mapper接口
    public interface SelectMapper {
        void insertUser(User user);
    }
    
  3. mapper映射文件

    useGeneratedKeys=“true” :表示该标签内的sql语句使用了自动递增的主键

    keyProperty=“id”:将自动递增的主键放在传过来的对象的id属性中,也可以设置为其它属性

    <insert id="insertUser" useGeneratedKeys="true" keyProperty="id">
        insert into t_user value (null,#{username},#{pwd},#{age},#{sex},#{email})
    </insert>
    
  4. 测试
    @Test
    public void insertUserTest() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
        User user = new User(null, "王五", "123", 23, '男', "123@123.com");
        mapper.insertUser(user);
        System.out.println(user);
    }
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

e_nanxu

感恩每一份鼓励-相逢何必曾相识

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值