特殊SQL语句的执行
引入
- MyBatis获取参数有两种方式:其中 #{ }特点是会自动添加单引号,适用于占位符填充,但是这种自动添加单引号的特点并不适用于某些SQL语句,故需要使用${ }来直接传输字符串
一、模糊查询
-
mapper接口
public interface SelectMapper { @MapKey("id") Map<String,Object> likeSelect(@Param("keyString") String keyStr); }
-
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},"%") -->
-
测试
@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); }
二、批量删除
-
mapper接口
public interface SelectMapper { void deleteMany(@Param("ids") String ids); }
-
mapper映射文件
不是使用#{ids},是因为#{}会自动将获取的参数加上一对单引号,in (‘2,3’)这种语法是不正确的
<delete id="deleteMany"> delete from t_user where id in (${ids}) </delete>
-
测试
@Test public void deleteManyTest() { SqlSession sqlSession = SqlSessionUtils.getSqlSession(); SelectMapper mapper = sqlSession.getMapper(SelectMapper.class); mapper.deleteMany("2,3"); }
三、动态设置表名
-
实际情况
在实际的生产中,如果一张表中的数据过多,会影响MySQL的性能,故会将这张表水平拆分成多张表,所以在查询一条数据时,就需要在几张表中共同查询,故查询语句中的表名是动态的
-
mapper接口
public interface SelectMapper { @MapKey("id") Map<String,Object> getUserByTableName(@Param("tableName") String tableName); }
-
mapper映射文件
<select id="getUserByTableName" resultType="map"> select * from ${tableName} </select>
-
测试
@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); }
四、添加功能中:获取自增的主键
-
实际情况
在普通的添加功能,自增列的值被设为null,执行过程中不显示该列的值,故无法执行一些涉及到该列的操作
-
mapper接口
public interface SelectMapper { void insertUser(User user); }
-
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>
-
测试
@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); }