文章目录

  • 前言
  • 一、在XML配置文件中实现
  • 1.增
  • 2.删
  • 3.改
  • 4.查
  • 5.万能的Map
  • 6.模糊查询LIKE
  • 7.分页
  • 二、利用注解实现



前言

通过前文Mybatis学习(一)—— 新手完成第一个Mybatis程序介绍的完成一个Mybatis的步骤可得,若再来新的需要操作的sql语句时,只需要更改第6步中的UserMapper接口内容,以及第7步中的Mapper.xml配置文件。很大程度简化了代码的编写。

本篇文章将从修改上述两个文件的内容,实现CURD功能。

tips:所有的增删改操作都需要事务的提交。

一、在XML配置文件中实现

1.增

UserMapper.java文件中:

public interface UserMapper {
    void addUser(User user);
}

Mapper.xml文件中:

<mapper namespace="UserMapper">
    <insert id="addUser" parameterType="com.ali.pojo.User">
    	<!-- 传值用% -->
        insert into mybatis.user (id, name, pwd) values (#{id}, #{name}, #{pwd});
    </insert>
</mapper>

测试:

@Test
 public void test1() {
     SqlSession sqlSession = MybatisUtils.getSqlSession();
     UserMapper mapper = sqlSession.getMapper(UserMapper.class);
     User user = new User(5, "dao","23");
     mapper.addUser(user);
     // 增删改事务要提交
     sqlSession.commit();
     sqlSession.close();
 }

2.删

UserMapper.java文件中:

public interface UserMapper {
    void deleteUser(int id);
}

Mapper.xml文件中:

<mapper namespace="UserMapper">
	<delete id="deleteUser" parameterType="int">
        delete from mybatis.user where id = #{id}
    </delete>
</mapper>

测试:

@Test
 public void test2() {
    qlSession sqlSession = MybatisUtils.getSqlSession();
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    mapper.deleteUser(6);
    sqlSession.commit();
    sqlSession.close();
 }

3.改

UserMapper.java文件中:

public interface UserMapper {
    void updateUser(User user);
}

Mapper.xml文件中:

<mapper namespace="UserMapper">
    <update id="updateUser" parameterType="com.ali.pojo.User">
    	<!-- #{} 括号中的名称需与字段名相同 -->
        update mybatis.user set name = #{name} where id = #{id}
    </update>
</mapper>

测试:

@Test
 public void test3() {
     SqlSession sqlSession = MybatisUtils.getSqlSession();
     UserMapper mapper = sqlSession.getMapper(UserMapper.class);
     User user = new User(5, "hiIIhi","23");
     mapper.updateUser(user);
     sqlSession.commit();
     sqlSession.close();
 }

4.查

UserMapper.java文件中:

public interface UserMapper {
    User getById(int id);
}

Mapper.xml文件中:

<mapper namespace="UserMapper">
    <select id="getById" parameterType="int" resultType="com.ali.pojo.User">
        select * from mybatis.user where id = #{id}
    </select>
</mapper>

测试:

@Test
 public void test4() {
     SqlSession sqlSession = MybatisUtils.getSqlSession();
     UserMapper mapper = sqlSession.getMapper(UserMapper.class);
     User user = mapper.getById(1);
     System.out.print(user);
     sqlSession.close();
 }

5.万能的Map

方法:使用Map<String,Object> map 传入参数
使用情况:实体类、数据库中的表,字段或者参数过多时,可通过Map传入参数,直接在sql取key值即可。
实现:下面的例子实现查询功能。

UserMapper.java文件中:

public interface UserMapper {
    User getById1(Map<String,Object> map);
}

Mapper.xml文件中:

<mapper namespace="UserMapper">
    <select id="getById1" parameterType="map" resultType="com.ali.pojo.User">
    	<!-- 这里的idnum可以任意命名,可不与表中属性名相同 -->
        select * from mybatis.user where id = #{idnum}
    </select>
</mapper>

测试:

@Test
 public void test4() {
     SqlSession sqlSession = MybatisUtils.getSqlSession();
     UserMapper mapper = sqlSession.getMapper(UserMapper.class);
     Map<String, Object> map = new HashMap<>();
     map.put("id", 2);
     User user = mapper.getById1(map);
     System.out.println(user); 
     sqlSession.commit();
     sqlSession.close();
 }

6.模糊查询LIKE

UserMapper.java文件中:

public interface UserMapper {
    List<User> getUserLike(String string);
}

Mapper.xml文件中:建议这里将模糊查询的通配符%写死,防止字符串拼接带来的sql注入。

<mapper namespace="UserMapper">
    <select id="getUserLike" resultType="com.ali.pojo.User">
        select * from mybatis.user where name like "%"#{values}"%"
    </select>
</mapper>

测试:

@Test
 public void test4() {
     SqlSession sqlSession = MybatisUtils.getSqlSession();
     UserMapper mapper = sqlSession.getMapper(UserMapper.class);
     List<User> user = mapper.getUserLike("王");
     System.out.print(user);
     sqlSession.close();
 }

7.分页

目的:通过将所有数据分段展示,减少数据的处理量
实现:

# 1.创建接口
import java.util.List;
import java.util.Map;

public interface UserMapper {
    List<User> getUserLimit(Map<String, Integer> map);
}


# 2.实现接口
<select id="getUserLimit" parameterType="map" resultType="User">
    select * from mybatis.user limit #{startIndex}, #{page}
</select>

# 3.测试
public class UserMapperTest {
	@Test
    public void test10() {
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        HashMap<String, Integer> map = new HashMap<>();
        map.put("startIndex", 0);
        map.put("page", 2);
        List<User> userLimit = mapper.getUserLimit(map);
        for (User user : userLimit) {
            System.out.println(user);
        }
        sqlSession.close();
    }
}

运行结果:

java mapper层update执行成功 数据库数据未变更_数据库


该结果加入了本文中介绍的日志功能。

二、利用注解实现

使用注解来映射简单语句会使代码显得更加简洁,但对于稍微复杂一点的语句,建议使用 XML 来映射语句。
实现:
1)在mybatis-config.xml文件中,指定注解的类。

<mappers>
    <mapper class="com.ali.dao.UserMapper"></mapper>
</mappers>

2)在接口中添加注解,以select为例,update、delete、insert同理。

public interface UserMapper {
    // 1.对不同操作注解不同关键词,在()中写入sql语句。
    @Select("select * from mybatis.user")
    List<User> getUserList();

    // 2.若sql语句中需要传参,sql中传入的参数用#{}表示
    // 接口的参数用 【@Param("数据库中字段名") 传入的数据类型 参数名】表示
    @Select("select * from mybatis.user where id = #{id}")
    User getById(@Param("id") int id);
}

3)测试:

public class UserMapperTest {
    @Test
    public void test(){
        // 1.获取执行sal的对象sqlSession
        SqlSession sqlSession = MybatisUtils.getSqlSession();

        // 2.获取并执行sql语句 方法:getMapper
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        List<User> userList = mapper.getUserList();
        // 输出结果
        for (User user : userList) {
            System.out.println(user);
        }

        // 3.关闭sqlSession连接
        sqlSession.close();
    }

    @Test
    public void test1() {
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        User user = mapper.getById(1);
        System.out.print(user);
        sqlSession.close();
    }
}