Mybatis增删改查基础

MyBatis可根据查询的结果类型、查询条件的不同进行统一处理。

1 查询数据

1.1 根据查询数据条数来分析不同的情况

1.1.1 查询单条数据

可以通过实体类、list集合、map等处理查询结果。

  • 通过实体类查询单条数据
java 复制代码
   User queryUserById(@Param("id") Integer id);
xml 复制代码
   <select id="queryUserById" resultType="User">
       select * from t_user where id = #{id}
   </select>
  • 通过map接收
java 复制代码
 Map<String, Object> queryUserMapById(@Param("id") Integer id);
xml 复制代码
 <select id="queryUserMapById" resultType="map">
     select * from t_user where id = #{id}
 </select>
1.1.2 查询多条数据
  • 通过类型为Map的list集合接收
java 复制代码
    List<Map<String, Object>> queryUserMapList();
xml 复制代码
    <select id="queryUserMapList" resultType="map">
      select * from t_user
    </select>
  • 通过类型为实体的list集合接收
java 复制代码
    List<User> selectUserList();
xml 复制代码
    <select id="selectUserList" resultType="User">
      select * from t_user
    </select>
  • 通过map接收

一条数据对应一个map,此时需要通过@MapKey注解设置map集合的键,值是每条数据对应的map集合

注意:此时一定不能使用实体类对象接收,会抛出TooManyResultsException

java 复制代码
    @MapKey("id")
    Map<String, Object> getAllUserToMap();
xml 复制代码
    <select id="getAllUserToMap" resultType="map">
    	select * from t_user
    </select>

1.2 其他情形

1.2.1 模糊查询
java 复制代码
    List<User> queryUserByLike(@Param("username") String username);
xml 复制代码
    <select id="queryUserByLike" resultType="User">
      <!-- select * from t_user where username like '%${username}%' -->
      <!-- select * from t_user where username like concat('%', #{username}, '%') -->
      select * from t_user where username like "%"#{username}"%"
    </select>
1.2.2 动态表名
java 复制代码
    List<User> queryAllUser(@Param("tableName") String tableName);
xml 复制代码
    <select id="queryAllUser" resultType="User">
      select * from ${tableName}
    </select>

2 新增数据

2.1 通过实体类新增
java 复制代码
    @Test
    public void testInsertUser(){
      SqlSession sqlSession = SqlSessionUtil.getSqlSession();
      UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
      User user = new User();
      user.setUsername("中华");
      user.setPassword("123456");
      user.setAge(32);
      user.setSex("男");
      int i = userMapper.insertUser(user);
      System.out.println(i);
    }
java 复制代码
    int insertUser(User user);
xml 复制代码
    <insert id="insertUser">
      insert into t_user values(null, #{username}, #{password}, #{age}, #{sex})
    </insert>

此处,表的主键设计为自增。

也可以明确设置主键为自增:

xml 复制代码
    <!--
       useGeneratedKeys:设置使用自增主键
       keyProperty:自增主键放在传所参数对象的字段属性名,会将生成的自增主键设置到入参的字段中
       keyColumn:自增主键对应表的字段名
    -->
    <insert id="insertUser" useGeneratedKeys="true" keyProperty="id" keyColumn="id" parameterType="User">
      insert into t_user values(null, #{username}, #{password}, #{age}, #{sex})
    </insert>
2.2 通过map新增
java 复制代码
    @Test
    public void testQueryByMapParam(){
      SqlSession sqlSession = SqlSessionUtil.getSqlSession();
      UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
      Map<String, Object> map = new HashMap<>();
      map.put("username", "李斯");
      map.put("age", 23);
      map.put("password", "000000");
      map.put("sex", "女");
      List<User> admin = userMapper.insertUser(map);
      admin.stream().forEach(System.out::println);
    }
java 复制代码
    int insertUser(Map<String, Object> map);
xml 复制代码
    <insert id="insertUser" useGeneratedKeys="true" keyProperty="id" keyColumn="id" parameterType="map">
      insert into t_user values(null, #{username}, #{password}, #{age}, #{sex})
    </insert>

3 修改数据

java 复制代码
    int udpateUserById(User user);
xml 复制代码
    <update id="udpateUserById" parameterType="User">
      update t_user set username = #{username}, password = #{password} where id = #{id}
    </update>

4 删除数据

4.1 单个删除
java 复制代码
    int deleteUserById(@Param("id") String id);
xml 复制代码
    <delete id="deleteUserById">
      delete from t_user where id = #{id}
    </delete>
4.2 批量删除
java 复制代码
    int deleteUserByIds(@Param("ids") String ids);
xml 复制代码
    <delete id="deleteUserByIds">
      delete from t_user where id in (${ids})
    </delete>
java 复制代码
    int result = deleteMapper.deleteUserByIds("5,6,7");
相关推荐
N维世界8 小时前
Mybatis-XML映射文件
xml·java·mybatis
慧一居士1 天前
MyBatis-Plus的完整使用示例,完整使用示例手册
mybatis
艺杯羹1 天前
MyBatis之核心对象与工作流程及SqlSession操作
java·mybatis
天天摸鱼的java工程师1 天前
MyBatis Plus 的实用技巧:从业务场景到代码实现
java·后端·mybatis
wuxuanok1 天前
Web后端开发-Mybatis
java·开发语言·笔记·学习·mybatis
netyeaxi2 天前
Java:使用spring-boot + mybatis如何打印SQL日志?
java·spring·mybatis
小七mod2 天前
【MyBatis】MyBatis与Spring和Spring Boot整合原理
spring boot·spring·mybatis
椰椰椰耶2 天前
【MyBatis】XML实现,配置方法和增、删、改、查
xml·oracle·mybatis
GJCTYU2 天前
spring中@Transactional注解和事务的实战理解附代码
数据库·spring boot·后端·spring·oracle·mybatis
DuelCode3 天前
Windows VMWare Centos Docker部署Springboot 应用实现文件上传返回文件http链接
java·spring boot·mysql·nginx·docker·centos·mybatis