增删改查
Mapper接口本质就是原来的Dao接口,只是为了方便我们的书写。一个mapper接口对应一个mapper映射文件。
将UserMapper更名为UserDao,说明本质
修改对应的mapper映射文件的namespace属性,对应上接口。
1.实体类
2.mybatis-config.xml
3.utils
4. 编写接口
package com.chao.dao;
import com.chao.pojo.User;
import java.util.List;
public interface UserDao {
//获取全部的用户
List<User> selectUser();
//根据id查找用户
User selectUserById(int id);
//添加一个用户
int addUser(User user);
//删除用户
int deleteUserByID(int id);
//修改用户
int updateUser(User user);
}
5.对应的mapper语句编写
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--mapper标签的namespace对应Mapper接口的类,包名+类名-->
<mapper namespace="com.chao.dao.UserDao">
<!--select标签的id对应映射接口的方法名字 resultType:返回结果的类型 中间就编写sql语句-->
<select id="selectUser" resultType="com.chao.pojo.User">
select * from user
</select>
<select id="selectUserById" resultType="com.chao.pojo.User">
select * from user where id = #{id}
</select>
<!--
我们需要接受一个自定义的对象(引用对象),需要设置parameterType,为参数类型
接收这个对象的值,直接使用 #{对象字段名}
-->
<insert id="addUser" parameterType="com.chao.pojo.User">
insert into user(id ,name, pwd) values (#{id},#{name},#{pwd})
</insert>
<delete id="deleteUserByID" parameterType="int">
delete from user where id = #{id}
</delete>
<update id="updateUser" parameterType="com.chao.pojo.User">
update user set name =#{name},pwd = #{pwd} where id = #{id}
</update>
</mapper>
6. 测试类
package com.chao.dao;
import com.chao.dao.UserDao;
import com.chao.pojo.User;
import com.chao.utils.MyBatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test;
import java.util.List;
public class UserMapperTest {
@Test
public void selectUser() {
//1.拿到sqlSessionFactory对象
SqlSessionFactory sqlSessionFactory = MyBatisUtils.getSqlSessionFactory();
//2.通过sqlSessionFactory对象openSession()创建一个sqlSession。
SqlSession sqlSession = sqlSessionFactory.openSession();
//3.通过sqlSession获得mapper对象 , 参数为映射文件对应的接口类的class对象
UserDao mapper = sqlSession.getMapper(UserDao.class);
//4.通过mapper对象来执行操作;
List<User> users = mapper.selectUser();
//获得结果集
for (User user : users) {
System.out.println(user);
}
sqlSession.close(); //关闭sqlSession
}
@Test
public void selectUserById(){
SqlSessionFactory sqlSessionFactory = MyBatisUtils.getSqlSessionFactory();
SqlSession sqlSession = sqlSessionFactory.openSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
//接口 对象名 = new 接口实现类
User user = mapper.selectUserById(1);
System.out.println(user);
sqlSession.close(); //关闭sqlSession
}
@Test
public void addUser(){
User user = new User(4,"chaowenli","123456");
SqlSessionFactory sqlSessionFactory = MyBatisUtils.getSqlSessionFactory();
SqlSession sqlSession = sqlSessionFactory.openSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
int i = mapper.addUser(user);
//没有插入成功的原因:没有提交事务;
sqlSession.commit(); //提交事务
sqlSession.close(); //关闭sqlSession
if (i>0){
System.out.println("插入成功!");
}
}
@Test
public void deleteUserByID(){
SqlSession sqlSession = MyBatisUtils.getSqlSessionFactory().openSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
int i = mapper.deleteUserByID(4);
//记得提交事务,否则删除不成功!
sqlSession.commit();//提交事务
sqlSession.close();//关闭
if (i>0){
System.out.println(i);
}
}
@Test
public void updateUser(){
SqlSession sqlSession = MyBatisUtils.getSqlSessionFactory().openSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
User user = new User(2,"chaowenli2","chaowenli2");
mapper.updateUser(user);
sqlSession.commit();
sqlSession.close();
}
}
总结CRUD注意点
1、事务
增,改,删需要提交事务!
增,改,删需要提交事务!
增,改,删需要提交事务!
2、乱码
如果出现乱码,先在sql中进行测试,sql没问题,就检查配置文件
jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf-8"
3、参数问题
如果是基本数据类型,可以省略,但建议写上
引用类型必须写指定的 包名+类名。