Mybatis学习笔记(四):实现查询分页、使用注解开发

Mybatis实现查询分页、使用注解开发

一、MySQL分页查询语句

select * from user limit #{startIndex},#{pageSize};
# startIndex : 起始位置 ,默认是0开始
# pageSize :页面大小

例如:

select * from user limit 0,3

二、Mybatis中使用limit实现分页

  1. 接口:

    //查询全部用户实现分页
    List<User> selectUserByLimit(Map<String,Integer> map);
    
  2. 编写对应mapper映射文件的方法

    <select id="selectUserByLimit" parameterType="Map" resultType="User">
        select * from mybatis.user limit #{startIndex},#{pageSize}
    select>
    
  3. 测试模拟分页

    @Test
    public void selectUserByLimit(){
    
        //创建sqlSession
        SqlSessionFactory sqlSessionFactory = MyBatisUtils.getSqlSessionFactory();
        SqlSession sqlSession = sqlSessionFactory.openSession();
    
        //模拟前端数据数据
        int currentPage = 2;//当前是第几页
        int pageSize = 2; //页面大小
    
        Map<String, Integer> map = new HashMap<String, Integer>();
        map.put("startIndex",(currentPage-1)*pageSize);
        map.put("pageSize",pageSize);
    
        //测试
        UserDao mapper = sqlSession.getMapper(UserDao.class);
        List<User> users = mapper.selectUserByLimit(map);
    
        for (User user : users) {
            System.out.println(user);
        }
    
        sqlSession.close();//关闭连接
    
    }
    

三、Mybatis中使用RowBounds实现分页

  1. 接口

    //查询全部用户实现分页使用RowBounds
    List<User> selectUserByRowBounds();
    
  2. Mapper映射文件

    <select id="selectUserByRowBounds" resultType="User">
        select * from mybatis.user
    select>
    
  3. 测试模拟分页

    @Test
    public void selectUserByRowBounds(){
        //创建sqlSession
        SqlSessionFactory sqlSessionFactory = MyBatisUtils.getSqlSessionFactory();
        SqlSession sqlSession = sqlSessionFactory.openSession();
    
        int currentPage = 2; //当前页
        int pageSize = 2; //页面大小
    
        RowBounds rowBounds = new RowBounds((currentPage - 1) * pageSize, pageSize);
    
        //注意点;使用RowBounds就不能使用getMapper了
        
        //selectList: 接收一个List
        //selectMap: 接收一个Map
        //selectOne : 接收只有一个对象的时候
        List<User> users = sqlSession.selectList("org.westos.dao.UserDao.selectUserByRowBounds", null, rowBounds);
    
        for (User user : users) {
            System.out.println(user);
        }
    }
    

limit 和 rowBounds区别

  • rowBounds 本质就是封装了limit
  • limit 是在SQL层面实现分页
  • rowBounds 在代码层面实现分页

四、Mybatis使用注解开发

注解可以替代一些xml文件中的配置,CRUD的注解:

  • @insert() 插入数据
  • @delete() 删除数据
  • @update() 更新数据
  • @select() 查询数据

UserMapper接口

package org.westos.dao;

import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;
import org.westos.pojo.User;

import java.util.List;

public interface UserMapper {
    //查询全部用户
    @Select("select * from user")
    List<User> selectUser();

    //通过ID查询用户
    @Select("select * from user where id = #{uid}")
    User selectUserById(@param("uid") int id);

    //添加用户
    @Insert("insert into user (id,name,pwd) values (#{id},#{name},#{pwd})")
    int addUser(User user);

    //修改用户信息
    @Update("update user set name = #{name},pwd = #{pwd} where id = #{id}")
    int updateUser(User user);

    //删除用户
    @Delete("delete from user where id=#{id}")
    int deleteUserById(@param("id") int id);
}

xml配置文件





<configuration>

    
    <properties resource="database.properties"/>


    
    <typeAliases>
        <typeAlias type="org.westos.pojo.User" alias="User"/>
        <package name="org.westos.pojo"/>
    typeAliases>

    
    <environments default="development">
        
        <environment id="development">
            
            <transactionManager type="JDBC"/>
            
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            dataSource>
        environment>
    environments>

    

    <mappers>
        
        
        
        <mapper class="org.westos.dao.UserMapper"/>
    mappers>

configuration>

测试类

package org.westos.dao;

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test;
import org.westos.pojo.User;
import org.westos.utils.MybatisUtils;

import java.sql.ParameterMetaData;
import java.util.Date;
import java.util.HashMap;
import java.util.List;

public class UserMapperTest {
    @Test
    public void selectUser(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        List<User> users = mapper.selectUser();
        for (User user : users) {
            System.out.println(user);
        }
    }


    @Test
    public void selectUserById(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        User user = mapper.selectUserById(3);
        System.out.println(user);
    }

    @Test
    public void insertUser(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        int i = mapper.addUser(new User(8, "小明", "236546"));
        System.out.println(i);
    }

    @Test
    public void updateUser(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        int i = mapper.updateUser(new User(3, "橘右京", "12344"));
        System.out.println(i);
    }

    @Test
    public void delete(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        mapper.deleteUserById(8);
    }
}

注意:

  1. 需开启事务自动提交
  2. 对于基本类型的数据@param参数尽量都写上,引用类型不需要;如果方法有多个参数,就必须填写。执行操作时以@param中的参数名为准

你可能感兴趣的:(mybatis,mybatis,mysql)