万能Map
假设,在我们的实体类中,或者数据库中的表,字段或者参数过多,我们应当考虑使用Map
Mapper接口:
package com.hang.dao;
import com.hang.pojo.User;
import java.util.List;
import java.util.Map;
/**
* 操作数据库的
* Dao==Mapper
*/
public interface UserMapper {
/**
* 使用Map查询
* @param map
* @return
*/
User getUserById2(Map<String,Object> map);
/**
* 使用万能的Map
* 好处:不需要知道数据库里面有什么 只需要去查对应的字段
* @param map
* @return
*/
int addUser2(Map<String,Object> map);
}
Mapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--namespace=绑定一个对应的Mapper/Dao接口,这个sql想要和UserDao这个接口发生关系-->
<mapper namespace="com.hang.dao.UserMapper">
<select id="getUserById2" parameterType="map" resultType="com.hang.pojo.User">
select * from mybatis.user where id = #{helloid} and name=#{helloname};
</select>
<!--SQL注入
select * from mybatis.user where id = ?
select * from mybatis.user where id = 1 or 1=1
-->
<!--map里面只用和key对应 它的参数类型是map 给它传的值是map里面的键(我们可以让它为任何东西 通过map可以随意制造参数 想怎么写sql就怎么写 而对象需要把所有的东西写出来)-->
<insert id="addUser2" parameterType="map">
insert into mybatis.user (id,name,pwd) values (#{userid},#{userName},#{pwd});
</insert>
</mapper>
test测试
package com.hang.dao;
import com.hang.pojo.User;
import com.hang.utils.MybatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class UserMapperTest {
@Test
public void addUser2(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
//需要传一个map,原来传的是User对象 现在需要new 一个Map
Map<String, Object> map = new HashMap<>();
map.put("userid",5);
map.put("userName","维姐");
map.put("pwd","66666666");
mapper.addUser2(map);//现在走的map 没有走之前的user
sqlSession.commit();
sqlSession.close();
}
@Test
public void getUserById2(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
Map<String, Object> map = new HashMap<>();
map.put("helloid",1);
map.put("helloName","航哥")
mapper.getUserById2(map);
sqlSession.close();
}
}
- Map传递参数,直接在sql中取出key即可! 【parameterType=“map”】
- 对象传递参数,直接在sql中取对象的属性即可!【parameterType=“Object”】
- 只有一个基本类型参数的情况下,可以直接在sql中取到!
- 多个参数用Map,或者注解!