MyBatis获取参数值的两种方式:${}和#{}。
${}的本质就是字符串拼接,#{}的本质就是占位符赋值。
${}使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引号。
#{}使用占位符赋值的方式拼接sql,此时为字符串类型或日期类型的字段进行赋值时,可以自动添加单引号。
#{}和${}都可以使用任意的名称来获取参数值,需要注意的是${}需要手动添加单引号。
Mapper接口:
/**
* 通过用户名获取User
* @param username
* @return
*/
User getUserByUserName(String username);
xml配置:
<select id="getUserByUserName" resultType="user">
select * from t_user where username = '${username}';
select>
单元测试:
@Test
public void testGetUserByUserName(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
User user = mapper.getUserByUserName("桑奇");
System.out.println(user);
}
当mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合中,以arg0,arg1…为键,以参数为值;以param1,param2,…为键,以参数为值。
因此只需要通过${}和#{}访问map集合的键就可以获取相应的值,${}需要手动加单引号。
mapper接口
/**
* 测试多个字面量参数如何获取
* @param username
* @param password
* @return
*/
User getLogin(String username,String password);
xml配置:
<select id="getLogin" resultType="User">
select * from t_user where username = #{arg0} and password = #{arg1};
select>
单元测试:
@Test
public void testLogin(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
User admin = mapper.getLogin("admin", "123456");
System.out.println(admin);
}
若mapper接口中的方法需要的参数为多个时,可以手动创建Map集合,将这些数据放在Map中,只需要通过#{}和${}访问Map集合的键就可以获取相对应的值,${}需要手动加单引号。
mapper接口
/**
* 测试map集合类型的参数
* @param map
* @return
*/
User checkLogin(Map map);
xml配置:
<select id="checkLogin" resultType="user">
select * from t_user where username = #{username} and password = #{password};
select>
单元测试:
@Test
public void testCheckLogin(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
Map<String,Object> map = new HashMap<>();
map.put("username","桑奇");
map.put("password","sangqi168");
User user = mapper.checkLogin(map);
System.out.println(user);
}
若mapper接口中的方法参数为实体类对象时,可以使用${}和#{},通过访问实体类对象中的属性名获取属性值,${}需要手动添加单引号。
mapper接口:
/**
* 测试实体类为参数如何获取
* @param user
* @return
*/
int insertUser(User user);
xml配置:
<insert id="insertUser">
insert into t_user values(null,#{username},#{password},#{age},#{sex},#{email});
insert>
单元测试:
@Test
public void testInsertUser(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
mapper.insertUser(new User(null,"桑奇","sangqi168",1,"男","[email protected]"));
}
可以通过@Param注解标识mapper接口中的方法参数。
此时会将这些参数放在map集合中,以@Param注解的value属性值为键,以参数为值;以param1,param2,…为键,以参数为值。通过访问Map集合中的键就可以获取相对应的值,${}需要手动添加单引号。
mapper接口
/**
*
* @param username
* @param password
* @return
*/
User checkLoginByParam(@Param("username") String username,@Param("password") String password);
xml配置:
<select id="checkLoginByParam" resultType="user">
select * from t_user where username = #{username} and password = #{password};
select>
单元测试:
@Test
public void testCheckLoginByParam(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
User user = mapper.checkLoginByParam("桑奇", "sangqi168");
System.out.println(user);
}
mapper接口
/**
* 通过id查询用户
*/
User getUserById(@Param("id") Integer id);
xml配置:
<select id="getUserById" resultType="user">
select * from t_user where id = #{id}
select>
单元测试:
@Test
public void testGetUserById(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
User user = mapper.getUserById(5);
System.out.println(user);
}
mapper接口
/**
* 查询所有用户信息
* @return
*/
List<User> getUserList();
xml配置
<select id="getUserList" resultType="user">
select * from t_user
select>
单元测试:
@Test
public void testGetUserList(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
List<User> userList = mapper.getUserList();
userList.forEach(System.out::println);
}
mapper接口:
/**
* 查询单个数据
*/
int getCount();
xml配置:
<select id="getCount" resultType="int">
select count(*) from t_user;
select>
单元测试
@Test
public void testGetCount(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
int count = mapper.getCount();
System.out.println(count);
}
mapper接口
/**
* 根据id查询用户信息为Map集合
* @return
*/
Map<String,Object> getUserMapById(@Param("id") Integer id);
xml配置:
<select id="getUserMapById" resultType="map">
select * from t_user where id = #{id};
select>
单元测试:
@Test
public void testGetUserMapById(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
Map<String, Object> map = mapper.getUserMapById(5);
System.out.println(map);
}
方式一:
mapper接口
/**
* 查询所有用户信息为map集合
* @return
* 将表中的数据以map集合的方式查询,一条数据对应一个map;若有多条数据,就会产生多个map集合,此
时可以将这些map放在一个list集合中获取
*/
List<Map<String, Object>> getAllUserToMap();
xml配置
<select id="getAllUserToMap" resultType="map">
select * from t_user
select>
单元测试
@Test
public void testGetAllUserToMap(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
List<Map<String, Object>> list = mapper.getUserMap();
list.forEach(System.out::println);
}
方式二:
mapper接口
/**
* 查询所有用户信息以map集合返回
*/
@MapKey("id")
Map<String,Object> getUserMap();
xml配置
<select id="getUserMap" resultType="map">
select * from t_user;
select>
单元测试
@Test
public void testGetUserMap(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession("mybatis-config.xml");
SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
Map<String, Object> map = mapper.getUserMap();
System.out.println(map);
}