select查询
- 根据id查询用户
- 在UserMapper中添加对应方法
public interface UserMapper {
//查询全部用户
List<User> getUserList();
//根据id查询用户
User getUserById(int id);
}
- 在UserMapper.xml中添加Select语句
<select id="getUserById" parameterType="int" resultType="site.duing.pojo.User">
select * from user where id = #{id}
</select>
- 使用
@Test
public void getUserById(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = mapper.getUserById(1);
System.out.println(user);
sqlSession.close();
}
- 根据用户名和密码查询用户
- 多个参数必须要在接口方法的参数前加 @Param属性来保证对应
//通过密码和名字查询用户
User selectUserByNP(@Param("username") String username,@Param("pwd") String pwd);
- Sql语句编写的时候,直接取@Param中设置的值即可,不需要单独设置参数类型
<select id="selectUserByNP" resultType="com.kuang.pojo.User">
select * from user where name = #{username} and pwd = #{pwd}
</select>
insert增加
- 给数据库增加一个用户
- 在UserMapper接口中添加对应的方法
//增加用户
int addUser(User user);
- 在UserMapper.xml中添加insert语句
- 自动将传入的User参数的三个属性(id,name,pwd)分解并填入对应的位置
<insert id="addUser" parameterType="site.duing.pojo.User">
insert into user (id,name,pwd) values (#{id},#{name},#{pwd})
</insert>
- 使用
@Test
public void addUser(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = new User(4,"李明","666888");
mapper.addUser(user);
sqlSession.commit();
sqlSession.close();
}
之前:
之后:
upda修改
- 修改用户的信息
- 同理,添加接口方法
//修改用户
int updateUser(User user);
- 在UserMapper.xml中添加update语句
- 自动将传入的User参数的三个属性(id,name,pwd)分解并填入对应的位置
<update id="updateUser" parameterType="site.duing.pojo.User">
update user set name=#{name},pwd=#{pwd} where id = #{id}
</update>
- 使用
@Test
public void updateUser(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = new User(2,"李四","777889");
mapper.updateUser(user);
sqlSession.commit();
sqlSession.close();
}
之前:
之后:
delete删除
- 根据id删除一个用户
- 添加接口方法
//删除用户
int deleteUser(int id);
- 在UserMapper.xml中添加delete语句
<delete id="deleteUser" parameterType="int">
delete from user where id = #{id}
</delete>
- 使用
@Test
public void deleteUser(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
mapper.deleteUser(3);
sqlSession.commit();
sqlSession.close();
}
之前:
之后:
注意
- 所有的增删改操作都需要提交事务!
sqlSession.commit();
- 接口所有的普通参数,尽量都写上
@Param
参数,尤其是多个参数时,必须写上! - 有时候根据业务的需求,可以考虑使用map传递参数!
- 为了规范操作,在SQL的配置文件中,我们尽量将parameterType和resultType都写上!