万能map
在字段比较多的时候用map非常方便,在项目中应用非常多。
接口中
//万能的map
int addUser1(Map<String, Object> map);
xml中
<!--用map类型,对象的属性可以直接取出来,传递map的key,
values后面可自定义名字,无需完全匹配数据库,但是测试的时候,字段要和values后面的一样
-->
<insert id="addUser1" parameterType="map">
insert into mybatis.user (id,name,password) values (#{id},#{username},#{password});
</insert>
测试中
@Test
public void addUser1() {
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
Map<String, Object> map = new HashMap<String, Object>();
map.put("id", 7);
map.put("username", "邓紫棋");
map.put("password", "7777777");
mapper.addUser1(map);
sqlSession.commit();
sqlSession.close();
}
总结:
Map传递参数,直接在sql中取出key即可。【parameterType=“map”】
对象传递参数,直接在sql中取对象的属性即可【parameterType=“Object”】
只有一个基本类型参数的情况下,可以直接在sql中取到。
对个参数用Map,或者用注解。