Mybatis学习笔记(三) 分页及注解开发

目录

一、Mybatis详细执行流程

二、分页

1、使用limit分页

(1)接口定义方法

(2)编写配置文件

(3)测试

2、RowBounds实现分页(了解即可)

(1)接口定义方法

(2)编写配置文件

(3)测试

3、PageHelper 分页插件(了解)

三、使用注解开发

1、步骤

(1)在核心配置文件中注入

(2)在接口中添加注解

(3)测试

2、注解实现增删改查

(1)实现类编写注解

(2)测试

(3)@Param

补充:


一、Mybatis详细执行流程

二、分页

1、使用limit分页

语法:select *from user limit ?,?

(1)接口定义方法

  List<User> getUserByLimit(Map<String,Integer> map);

(2)编写配置文件

  <select id="getUserByLimit" parameterType="map" resultMap="UserMap">
        select * from mybatis.user limit #{startIndex},#{pageSize}
    </select>

(3)测试

推断:起始位置 = (当前页面 - 1 * 页面大小
    @Test
    public void getUserByLimittest(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserDao mapper = sqlSession.getMapper(UserDao.class);
        HashMap<String, Integer> map = new HashMap<String, Integer>();
        map.put("startIndex",0);
        map.put("pageSize",2);
        List<User> limit = mapper.getUserByLimit(map);
        for (User user :
                limit) {
            System.out.println(user);
        }
        sqlSession.close();
    }

2、RowBounds实现分页(了解即可)

(1)接口定义方法

List<User> getUserByRowBounds();

(2)编写配置文件

<select id="getUserByRowBounds" resultType="user">
select * from user
</select>

(3)测试

  @Test
    public void getUserByLimittest(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        RowBounds rowBounds = new RowBounds(0,2);
        List<User> users = 
sqlSession.selectList("com.kuang.mapper.UserMapper.getUserByRowBounds", null, rowBounds);
        for (User user :
                users) {
            System.out.println(user);
        }
        sqlSession.close();
    }

3、PageHelper 分页插件(了解)

链接:https://pagehelper.github.io/

三、使用注解开发

注解也是运用映射的原理实现的,使用注解后就不再需要mapper.xml映射文件了

1、步骤

(1)在核心配置文件中注入

   <mappers>
        <mapper class="com.kuang.dao.UserDao"/>
    </mappers>

(2)在接口中添加注解

   @Select("select * from user")
    List<User> getUsers();

(3)测试

    @Test
    public void test(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserDao mapper = sqlSession.getMapper(UserDao.class);

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

    }

2、注解实现增删改查

(1)实现类编写注解

    @Select("select * from user")
    List<User> getUsers();

    @Insert("insert into user(id,name,pwd) values(#{id},#{name},#{password})")
    int addUser(User user);

    @Update("update user set name=#{name},pwd=#{password} where id=#{id}")
    int upDateUser(User user);

    @Delete("delete from user where id=#{uid}")
    int deleteUser(@Param("uid") int id);

(2)测试

注意:增删改需要提交事务

(可在配置文件中设置自动提交   sqlSessionFactory.openSession(true);)

        List<User> users = mapper.getUsers();
        for (User user : users) {
            System.out.println(user);
        }
        int user = mapper.addUser(new User(4, "王五", "123123"));
        mapper.upDateUser(new User(4,"赵六","000000"));
        mapper.deleteUser(4);

(3)@Param

@Param注解用于给方法参数起一个名字。以下是总结的使用原则:
①在方法只接受一个参数的情况下,可以不使用@Param,建议使用以规范代码。
②在方法接受多个参数的情况下,建议一定要使用@Param注解给参数命名。
③如果参数是 JavaBean(即实体类) , 则不能使用@Param
④不使用@Param注解时,参数只能有一个,并且是Javabean或基本类型
⑤在sql中引用的就是在@Param中设置的属性名。

补充:

如果参数是JavaBean,则#{}中的内容一定要与实体类中的属性名一致,否则会报错。

如果参数是基本类型,#{}中的内容可随意取。

如果参数是Map,#{}中的内容为键名。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值