百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

分页查询+通用mapper(Java数据库编程)

wptr33 2024-12-15 17:12 16 浏览

MyBatis

分页查询

分页简述

  • 搭建环境

提供的资料包含了当天通用 mapper 的内容,一并导入jar 包和工具类即可。JavaBean 的定义和之前一样,不再提供

Mybatis 开发中我们采用 pagehelper 插件。

  • 导入jar 包:
  • 添加插件

<!-- 插件(放在 environments 标签上方即可) -->

<plugins>

<plugin interceptor="com.github.pagehelper.PageHelper">

<property name="dialect" value="mysql"/>

<property name="rowBoundsWithCount" value="true"/>

</plugin>

</plugins>

  • 案例 1:分页查询用户信息需求说明

要求:每次查询仅展示 3 条数据

    • API 讲解
  • PageHelper 类:

静态方法

描述

startPage(int pageNum,int pageSize)

设置本次查询的分页数据。(在本次查询之前设置) 参数:

  • pageNum:当前展示数据的第几页
  • pageSize:一页显示多少条数据
  • PageInfo 对象:

方法

描述

getPageNum()

获取当前是第几页

getTotal()

获取总记录数

getPages()

获取总页数

getPageSize()

获取一页显示多少条数据

getList()

获取当前页的所有数据

    • 代码实现
  • 测试类

/**

* 分页查询

*/

@Test

public void run2(){

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//1、设置分页数据

PageHelper.startPage(1, 3);

//2、正常查询所有(查询时已经进行分页)

//注意,此时返回的ulist,不是ArrayList,而是继承了ArrayList的Page

类对象,

//page类重写了toString,所以建议使用遍历来展示数据



List<User> ulist = dao.selectAll();



//3、封装分页数据(建议使用 pageInfo 对象封装转换,可以操作功能)



PageInfo<User> pageInfo = new PageInfo<User>(ulist);



System.out.println("当前页:"+pageInfo.getPageNum());



System.out.println("总记录数:"+pageInfo.getTotal());



System.out.println("总页数:"+pageInfo.getPages());



System.out.println("一页显示记录数:"+pageInfo.getPageSize());



//当前页的数据



for(User u:pageInfo.getList()){



System.out.println(u);



}



MyBatisUtils.close();


}


  • UserDao

@Select("select * from user")

List<User> selectAll();

  1. 通用 Mapper
  • 概述

MyBatis 通用 Mapper 是用来简化 MyBatis 开发,它提供了一个名为 Mapper<T>的接口。这个 Mapper 接口中提供了常见的 DAO 方法,例如添加、修改、删除、查询等。我们在编写 DAO 接口时继承这个通用 Mapper 接口就可以得到 N 多常用方法。

如果通用 Mapper 中的方法还不能满足产你的需求,那么你只需在 DAO 中添加额外的方法即可。

public interface UserDao extends Mapper<User> {

}

//UserDao 可以使用从 Mapper 继承过来的所有方法

  • 搭建环境
  • 导入jar 包
  • 修改工具类【直接复制使用即可】

factory = new SqlSessionFactoryBuilder().build(is);

=

is

// 会话工厂

private static SqlSessionFactory factory; static{

try {

// 1.1 加载核心配置文件

InputStream Resources.getResourceAsStream("SqlMapConfig.xml");

// 1.2 获得工厂

public class MyBatisUtils {

} catch (Exception e) {

throw new RuntimeException(e);

}

}

private static ThreadLocal<SqlSession> local = new ThreadLocal<>();

/**

  • 获得新会话
  • @return

*/

private static SqlSession openSession(){ SqlSession sqlSession = local.get(); if(sqlSession == null){

sqlSession = factory.openSession();

//创建一个 MapperHelper

MapperHelper mapperHelper = new MapperHelper();

//特殊配置

Config config = new Config();

// 设置 UUID 生成策略

// 配置 UUID 生成策略需要使用 OGNL 表达式

// 默 认 值 32 位 长度:@java.util.UUID@randomUUID().toString().replace("-", "")

//config.setUUID("");

// 主键自增回写方法,默认值 MYSQL,详细说明请看文档

// config.setIDENTITY("HSQLDB");

// 支持方法上的注解

// 3.3.1 版本增加config.setEnableMethodAnnotation(true); config.setNotEmpty(true);

// 序列的获取规则,使用{num}格式化参数,默认值为{0}.nextval,针对 Oracle

// 可选参数一共 3 个,对应 0,1,2,分别为 SequenceName,ColumnName,

PropertyName

//config.setSeqFormat("NEXT VALUE FOR {0}");

// 设置全局的 catalog, 默认为空, 如果设置了值, 操作表时的 sql 会是

catalog.tablename

//config.setCatalog("");

// 设置全局的 schema, 默认为空, 如果设置了值, 操作表时的 sql 会是

schema.tablename

// 如果同时设置了 catalog,优先使用 catalog.tablename

//config.setSchema("");

// 主键自增回写方法执行顺序,默认 AFTER,可选值为(BEFORE|AFTER)

//config.setOrder("AFTER");

//设置配置mapperHelper.setConfig(config);

// 注册通用 Mapper 接口 - 可以自动注册继承的接口mapperHelper.registerMapper(Mapper.class); mapperHelper.registerMapper(MySqlMapper.class);

// mapperHelper.registerMapper(SqlServerMapper.class);

// mapperHelper.registerMapper(IdsMapper.class);

//配置完成后,执行下面的操作

mapperHelper.processConfiguration(sqlSession.getConfiguration());

local.set(sqlSession);

}

return sqlSession;

}

/**

  • 获得 mapper
  • @param clazz
  • @return

*/

public static <T> T getMapper(Class<T> clazz){ return openSession().getMapper(clazz);

}

/**

  • 释放资源

*/

public static void close() {

SqlSession sqlSession = openSession(); if(sqlSession != null){

sqlSession.close();

}

}

/**

  • 提交并释放资源
  • @param sqlSession

*/

public static void commitAndclose() { SqlSession sqlSession = openSession(); if(sqlSession != null){

sqlSession.commit(); close();

}

}

/**

  • 回滚并释放资源
  • @param sqlSession

*/

public static void rollbackAndclose() { SqlSession sqlSession = openSession(); if(sqlSession != null){

sqlSession.rollback(); close();

}

}

}

JavaBean 编写@Table 和@Id

@Table(name=”表名”) : 表示当前 JavaBean 对应哪张 MySQL 表,默认对应 JavaBean

名称的表格

@Id :通用 mapper 必须设置,用于标识当前主键字段

@Table(name="t_user")

public class User implements Serializable {

/**

  • uid INT(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
  • username VARCHAR(32) NOT NULL COMMENT '用户名称',
  • birthday DATE DEFAULT NULL COMMENT '生日',
  • sex CHAR(1) DEFAULT NULL COMMENT '性别',
  • address VARCHAR(256) DEFAULT NULL COMMENT '地址'

*/

@Id

private Integer uid; private String username; private Date birthday; private String sex; private String address;

public User(Integer uid, String username, Date birthday, String sex, String address) {

this.uid = uid;

this.username = username;

this.birthday = birthday; this.sex = sex; this.address = address;

}

@Override

public String toString() { return "User{" +

"uid=" + uid +

", username='" + username + '\'' + ", birthday=" + birthday +

", sex='" + sex + '\'' +

", address='" + address + '\'' + '}';

}

public User() {

}

public Integer getUid() { return uid;

}

public void setUid(Integer uid) { this.uid = uid;

}

public String getUsername() { return username;

}

public void setUsername(String username) { this.username = username;

}

public Date getBirthday() { return birthday;

}

public void setBirthday(Date birthday) { this.birthday = birthday;

}

public String getSex() {

return sex;

}

public void setSex(String sex) { this.sex = sex;

}

public String getAddress() { return address;

}

public void setAddress(String address) { this.address = address;

}

}

Dao 接口继承通用 Mapper

import tk.mybatis.mapper.common.Mapper;

public interface UserDao extends Mapper<User> {

}

  • 编写测试类

通过主键查询

  • 确定主键,否则所有字段都是主键
  • 测试类

//1、获取Dao实现类对象

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、调用通过Mapper中继承而来的方法 User user = dao.selectByPrimaryKey(8); System.out.println(user);

//3、关闭资源

MyBatisUtils.close();








}

* 通过主键UID查询

*/ @Test

public void run1(){













/**

    • 查询所有
  • 测试类

//1、获取Dao实现类对象

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、调用通过Mapper中继承而来的方法

List<User> list = dao.selectAll();





* 查询所有数据

*/ @Test

public void run2(){









/**




for(User u:list){

System.out.println(u);



}



//3、关闭资源



MyBatisUtils.close();


}


    • 分页查询
  • 测试类:

//1、获取Dao实现类对象

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、设置分页PageHelper.startPage(1, 3);

//3、调用通过Mapper中继承而来的方法List<User> list = dao.selectAll();

//4、封装分页数据

PageInfo<User> pageInfo = new PageInfo<User>(list); for(User u:pageInfo.getList()){

System.out.println(u);

}

//5、关闭资源

MyBatisUtils.close();














}

* 分页查询

*/ @Test

public void run3(){



















/**

    • 添加
  • 测试类:


/**

* 添加: 测试 1,当前日期,男,沭阳

*/

@Test

public void run4_1(){

//1、获取Dao

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、调用Dao 方法

//添加数据,遇到null,添加null

int row = dao.insert(new User(null, "测试 1", new Date(), "男", "沭阳"));

//添加数据,遇到null,先尝试用数据库该字段默认值,该字段没有默认值,继续用null

//int row = dao.insertSelective(new User(null, "测试 1", new Date(), "男", "

沭阳"));

System.out.println("添加成功了"+row+"条数据");

//3、提交事务并关闭会话

MyBatisUtils.commitAndClose();

}

    • 根据 ID 修改
  • 测试类:

//1、获取Dao实现类对象

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、调用通过Mapper中继承而来的方法

User user = new User(9, "小王2",new Date(), "女", "测试区域2"); int i = dao.updateByPrimaryKey(user);

System.out.println("成功修改"+i+"行数据");

//3、关闭资源

MyBatisUtils.commitAndClose();









}

* 修 改

*/ @Test

public void run5(){
















/**

    • 根据 ID 删除
  • 测试类:

/**

* 删 除

*/

@Test

public void run6(){





//1、获取Dao实现类对象

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、调用通过Mapper中继承而来的方法



int i = dao.deleteByPrimaryKey(9);



System.out.println("成功删除"+i+"行数据");



//3、关闭资源



MyBatisUtils.commitAndClose();


}


    • 多条件查询(and 模糊+and 等于+and 区间)

需求:用户名包含“小” 并且 性别为“男” 并且 出生日期在“2018-01-01”~“2018- 04-01”

  • 测试类:

//1、获取Dao实现类对象

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、多条件查询

/**创建条件*/

Example example = new Example(User.class);

Criteria c = example.createCriteria();

//username模糊查询c.andLike("username", "%小%");

//sex等号查询c.andEqualTo("sex", "男");

//birthday区间查询

c.andBetween("birthday", "2018-01-01", "2018-04-01");

/**进行查询*/

List<User> ulist = dao.selectByExample(example); for(User u:ulist){

System.out.println(u);

}

//3、关闭资源

MyBatisUtils. close();




















}
























*/

@Test

public void run7(){

/**

* 多条件查询

* 用户名包含“小” 并且 性别为“男” 并且 出生日期在“2018-01-01”~

“2018-04-01”

    • 多条件查询(andIn+and 非空)

需求:查询用户 ID 为 1 或 3 或 5 的数据,并且要求地址不能为空

  • 测试类:

//1、获取Dao实现类对象

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、多条件查询

/**创建条件*/

Example example = new Example(User.class); Criteria c = example.createCriteria();

//uid 的in查询

List<Integer> uidList = new ArrayList<Integer>(); uidList.add(1);

uidList.add(3); uidList.add(5);

c.andIn("uid", uidList);

//address 的不为空查询c.andIsNotNull("address");

/**进行查询*/

List<User> ulist = dao.selectByExample(example); for(User u:ulist){

System.out.println(u);

}

//3、关闭资源

MyBatisUtils. close();






















}




























* 多条件查询

* 查询用户ID为1或3或5的数据,并且要求地址不能为空

*/ @Test

public void run8(){

/**

    • 多条件查询(or 查询)

需求:查询用户名为“管理员” 或者 性别为“女”的所有数据

  • 测试类:

//1、获取Dao实现类对象

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、多条件查询

/**创建条件*/

Example example = new Example(User.class);

Criteria c = example.createCriteria();

//username 的等于查询c.andEqualTo("username", "管理员");

//sex 的等于查询c.orEqualTo("sex", "女");

/**进行查询*/

List<User> ulist = dao.selectByExample(example); for(User u:ulist){

System.out.println(u);

}

//3、关闭资源

MyBatisUtils.close();


















}
























* 多条件查询

* 查询用户名为“管理员” 或者 性别为“女”的所有数据

*/ @Test

public void run9(){

/**

    • 批量删除(andIn)

需求:根据 ID 删除信息,将 1,3,5 三条信息删除

//1、获取Dao实现类对象

UserDao dao = MyBatisUtils.getMapper(UserDao.class);

//2、调用通过Mapper中继承而来的方法

//创建条件

Example example = new Example(User.class); Criteria c = example.createCriteria();

//uid in

List<Integer> list = new ArrayList<Integer>(); list.add(1);

list.add(3);

list.add(5); c.andIn("uid", list);

//执行按条件删除

int row = dao.deleteByExample(example); System.out.println("成功删除了"+row+"条数据");

//3、关闭资源

MyBatisUtils.commitAndClose();


















}

* 按条件删除

*/ @Test

public void run10(){

/**























总结:

1、条件查询一定要先创建查询条件:

2、遇到并且条件,就用 andXxx 遇到或者条件,就用 orXxx

3、最后调用方法查询即可:

  • 通用 Mapper-API(附录)
  • 查询方法

方法名

描述

T selectOne(T t)

根据实体中的属性进行查询,只能有一个返回值,有多个

结果是抛出异常,查询条件使用等号

List<T> select(T t)

根据实体中的属性值进行查询,查询条件使用等号

List<T> selectAll()

查询全部结果

int selectCount(T t)

根据实体中的属性查询总数,查询条件,使用等号

T selectByPrimaryKey(Object key)

根据主键字段进行查询

boolean existsWhithPrimaryKey(Object

key)

根据主键字段查询记录是否存在

List<T> selectByExample(Object

example)

根据 Example 条件进行查询

T selectOneByExample(Object example)

根据Example 条件进行查询,只能有一个返回值

int selectCountByExample(Object

example)

根据 Example 条件进行查询记录数

  • 插入方法

方法名

描述

int insert(T t)

保存一个实体,设置为 null 的属性会作为 null 保存,不使用该字段默认值

int intsertSelective(T t)

保存一个实体,设置为 null 的属性不会直接保存 null,而是先尝试使用数

据库默认值保存

  • 更新方法

方法名

描述

int updateByPrimaryKey(T t)

根据主键更新实体全部字段,若属性设置为 null,则该字段

的值更新为 null

int updateByPrimaryKeySelective(T t)

根据主键更新实体,若属性设置为 null,则忽略该属性

  • 删除方法

方法名

描述

int delete(T t)

根据实体属性作为条件进行删除,查询条件使用等号

int deletePrimaryKey(Object key)

根据主键字段进行删除

int deleteByExample(Object example)

根据 Example 条件删除数据

相关推荐

Linux高性能服务器设计

C10K和C10M计算机领域的很多技术都是需求推动的,上世纪90年代,由于互联网的飞速发展,网络服务器无法支撑快速增长的用户规模。1999年,DanKegel提出了著名的C10问题:一台服务器上同时...

独立游戏开发者常犯的十大错误

...

学C了一头雾水该咋办?

学C了一头雾水该怎么办?最简单的方法就是你再学一遍呗。俗话说熟能生巧,铁杵也能磨成针。但是一味的为学而学,这个好像没什么卵用。为什么学了还是一头雾水,重点就在这,找出为什么会这个样子?1、概念理解不深...

C++基础语法梳理:inline 内联函数!虚函数可以是内联函数吗?

上节我们分析了C++基础语法的const,static以及this指针,那么这节内容我们来看一下inline内联函数吧!inline内联函数...

C语言实战小游戏:井字棋(三子棋)大战!文内含有源码

井字棋是黑白棋的一种。井字棋是一种民间传统游戏,又叫九宫棋、圈圈叉叉、一条龙、三子旗等。将正方形对角线连起来,相对两边依次摆上三个双方棋子,只要将自己的三个棋子走成一条线,对方就算输了。但是,有很多时...

C++语言到底是不是C语言的超集之一

C与C++两个关系亲密的编程语言,它们本质上是两中语言,只是C++语言设计时要求尽可能的兼容C语言特性,因此C语言中99%以上的功能都可以使用C++完成。本文探讨那些存在于C语言中的特性,但是在C++...

在C++中,如何避免出现Bug?

C++中的主要问题之一是存在大量行为未定义或对程序员来说意外的构造。我们在使用静态分析器检查各种项目时经常会遇到这些问题。但正如我们所知,最佳做法是在编译阶段尽早检测错误。让我们来看看现代C++中的一...

ESL-通过事件控制FreeSWITCH

通过事件提供的最底层控制机制,允许我们有效地利用工具箱,适时选择使用其中的单个工具。FreeSWITCH是一个核心交换与混合矩阵,它周围有几十个模块提供各种功能特性。我们完全控制了所有的即时信息,这些...

物理老师教你学C++语言(中篇)

一、条件语句与实验判断...

C语言入门指南

当然!以下是关于C语言入门编程的基础介绍和入门建议,希望能帮你顺利起步:C语言入门指南...

C++选择结构,让程序自动进行决策

什么是选择结构?正常的程序都是从上至下顺序执行,这就是顺序结构...

C++特性使用建议

1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...

C++程序员学习Zig指南(中篇)

1.复合数据类型结构体与方法的对比C++类:...

研一自学C++啃得动吗?

研一自学C++啃得动吗?在开始前我有一些资料,是我根据网友给的问题精心整理了一份「C++的资料从专业入门到高级教程」,点个关注在评论区回复“888”之后私信回复“888”,全部无偿共享给大家!!!个人...

C++关键字介绍

下表列出了C++中的常用关键字,这些关键字不能作为变量名或其他标识符名称。1、autoC++11的auto用于表示变量的自动类型推断。即在声明变量的时候,根据变量初始值的类型自动为此变量选择匹配的...