1、namespace
namespace中的包名要和Dao/mapper接口的包名一致!
2、select
选择、查询语句:
-
id:就是对应的namespace中的方法名
-
resultType:Sql语句执行的返回值!
-
parameterType:参数类型!
-
编写接口
//查询全部用户 List<User> getUserList(); //更据ID查询用户 User getUserById(int id);
-
编写对应的mapper中的sql语句
<!--select查询语句--> <select id="getUserList" resultType="com.zhao.pojo.User"> select * from mybatis.user </select> <select id="getUserById" resultType="com.zhao.pojo.User"> select * from mybatis.user where id = #{id}; </select>
-
测试
@Test public void test(){ //第一步;获取SqlSession对象 SqlSession sqlSession = MybatisUtils.getSqlSession(); try { //方式一 //执行SQL UserMapper userMapper = sqlSession.getMapper(UserMapper.class); List<User> userList = userMapper.getUserList(); //方式二: //List<User> userList = sqlSession.selectList("com.zhao.dao.UserDao.getUserList"); for (User user : userList){ System.out.println(user); } }finally { //关闭SqlSession sqlSession.close(); } } @Test public void getUserById(){ SqlSession sqlSession = MybatisUtils.getSqlSession(); UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User user = userMapper.getUserById(1); System.out.println(user); sqlSession.close(); }
-
3、Insert
<insert id="addUser" parameterType="com.zhao.pojo.User" >
insert into mybatis.user (id,name,pwd) values (#{id},#{name},#{pwd});
</insert>
4、update
<update id="updateUser" parameterType="com.zhao.pojo.User">
update mybatis.user set name=#{name },pwd=#{pwd} where id=#{id};
</update>
5、delete
<delete id="deleteUser" parameterType="int">
delete from mybatis.user where id = #{id};
</delete>
注意点:增删改需要提交事务
6、分析错误
-
标签不要匹配错
-
resouce绑定mapper,需要使用路径
<!--每一个Mapper.xml都需要在mybatis核心配置中注册--> <mappers> <mapper resource="com/zhao/dao/UserMapper.xml"/> </mappers>
-
程序配置文件必须符合规范
-
NullPointerException,没有注册到资源
-
输出的xml文件中存在中文乱码问题!
-
maven资源没有导出
7、万能的Map
假设,我们的实体类,或者数据库中的表,字段或者参数过多,我们应当考虑使用Map!
//万能的Map
int addUser2(Map<String,Object> map);
<!--对象中的属性,可以直接取出来
传递map的key
-->
<insert id="addUser2" parameterType="map">
insert into mybatis.user (id,name,pwd) values (#{userid},#{userName},#{passWord});
</insert>
@Test
public void addUser2(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
HashMap<String,Object> map = new HashMap<String,Object>();
map.put("userid",6);
map.put("userName","Hello");
map.put("passWord","321456");
userMapper.addUser2(map);
sqlSession.commit();
sqlSession.close();
}
Map传递参数,直接在sql中取出key即可!【paramaterType=“map”】
对象传递参数,直接在sql中取出对象即可!【paramaterType=“Object”】
只有一个基本类型参数的情况下,可以直接在sql中取到!
多个参数用Map,或者注解!
8、思考题
模糊查询怎么写?
-
java代码执行的时候,传递通配符%%
List<User> getUserLike(String value);
-
在sql拼接中使用通配符!
select * from mybatis.user where name like "%"#{value}"%"