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属性的值