这里面我们介绍一下springboot与mybatis的集成,主要完成了mybatis的真分页。一个成熟的人往往发觉可以责怪的人越来越少,人人都有他的难处。

springboot简单集成mytbatis

一、集成mybatis需要额外的依赖

我们使用的是mysql数据库,需要mysql的驱动,这里就不列举springboot的基础依赖了。

<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>

在application.yml中配置mybatis的一些属性。mybatis_config.xml是mybatis的配置,sql_*.xml是sql语句。

mybatis:
mapper-locations: classpath:config/mweb/sql_*.xml
config-location: classpath:config/setting/mybatis_config.xml
type-aliases-package: com.linux.huhx.learn.mybatis.bean

  这里面引入mybatis_config.xml文件,主要是为了添加分页的拦截器。这个后面再做详细介绍,至此mybatis的配置就告一段落。下面我们通过实例来体会一下项目中经常遇到的问题。

springboot配置mybatis的分页

一、mybatis的拦截器实现真分页

  mybatis内置实现的分页是逻辑分页,并没有做到真正的分页。现在我们在springboot中集成一下mybatis的真分页功能。首先添加依赖pagehelper。

<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>${pagehelper-version}</version>
</dependency>

  在mybatis的配置文件中,添加plugin。主体修改文件是上面的mybatis_config.xml,内容如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration>
<plugins>
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<property name="helperDialect" value="mysql"/>
</plugin>
</plugins>
</configuration>

  我们的实体Bean类User,位于com.linux.huhx.learn.mybatis.bean包内,也就是上述配置的type-aliases-package,这样在涉及到实体类写sql语句的时候,可以不用写包名。

public class User implements Serializable {
private String userId;
private String username;
private String password;
private int sex;
private String phoneNumber;
private String address;
private Date birthday
}

  User类与数据库的puser表字段是对应开来的,这里面省略了bean类的get和set方法。后续的实体bean都会省略这些set和get的方法。

@RestController
@RequestMapping("/pageHelper")
public class PageHelperAction { @Resource
private SqlSession sqlSession; @RequestMapping("/getUser")
public ResponseBean<List<User>> getUsersByPage() {
PageHelper.startPage(2, 3);
List<User> pagelist = this.sqlSession.selectList("user.queryAllUserInfo");
return ResultUtil.success(pagelist);
}
}

我们的user.queryAllUserInfo对应的sql语句如下:

<!-- 分页查询所有的用户 -->
<select id="queryAllUserInfo" resultType="User">
SELECT
userId,
username,
password,
address,
phoneNumber,
birthday,
sex
FROM
puser
ORDER BY
userId DESC
</select>

通过请求下面的controller,get的url为:http://localhost:9998/pageHelper/getUser。通过下面的日志,我们知道实现的是真的分页。

::35.032 [http-nio--exec-] DEBUG user.queryAllUserInfo_COUNT - ==>  Preparing: SELECT count() FROM puser
::35.057 [http-nio--exec-] DEBUG user.queryAllUserInfo_COUNT - ==> Parameters:
::35.071 [http-nio--exec-] DEBUG user.queryAllUserInfo_COUNT - <== Total:
::35.074 [http-nio--exec-] DEBUG user.queryAllUserInfo - ==> Preparing: SELECT userId, username, password, address, phoneNumber, birthday, sex FROM puser ORDER BY userId DESC LIMIT ?, ?
::35.074 [http-nio--exec-] DEBUG user.queryAllUserInfo - ==> Parameters: (Integer), (Integer)
::35.078 [http-nio--exec-] DEBUG user.queryAllUserInfo - <== Total:

需要注意的是在查询数目的总数的时候,没有加上order by userId desc。这样的处理确认挺好的,没有额外的查询开销。

二、使用Mapper的接口编程方式

  网上用mybatis的大多都是使用mapper的接口方式,这里面我们对这种方式做一个了解。至于我为什么没有使用这种方式,由于使用了动态代理,性能是没有上述直接sqlSession.selectList等那么好,可能这个是主要的原因(使用mapper的方式确实可以避免很多问题,比如namespace的冲突、方法返回类型等问题)。

首先定义一个mapper的接口:

package com.linux.huhx.learn.mybatis.mapper;

import com.linux.huhx.learn.mybatis.bean.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select; @Mapper
public interface UserMapper { @Select("select * from puser where userId = #{userId}")
User queryUserById(@Param("userId") String userId);
}

在我们测试控制器中,我们测试一下Mapper的效果:

@RestController
@RequestMapping("/mapper")
public class UserMapperAction { @Resource
private UserMapper userMapper; @GetMapping("user")
public ResponseBean<User> getUserById(@RequestParam("userId") String userId) {
User user = userMapper.queryUserById(userId);
return ResultUtil.success(user);
}
}

通过get请求:http://localhost:9998/mapper/user?userId=1。我们得到以下的返回数据:

{
"returnCode": ,
"returnMessage": "成功",
"response": {
"userId": "",
"username": "huhx1",
"password": "",
"sex": ,
"phoneNumber": null,
"address": "",
"birthday": null
}
}

  这种方式确实写起来比较舒服,不用额外的去维护一个写sql的xml文件。而且一个Mapper的接口就完成了整个Dao的代码。当然也可以不用类似于@Select注解,sql语句也可以定义在xml里面。

@GetMapping("user2")
public ResponseBean<User> getUserById2(@RequestParam("userId") String userId) {
User user = userMapper.queryUserByXMlId(userId);
return ResultUtil.success(user);
}

在上述的userMapper类里面添加方法queryUserByXMlId:

User queryUserByXMlId(String userId);

添加的xml文件里面,我们的sql语句如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.linux.huhx.learn.mybatis.mapper.UserMapper">
<select id="queryUserByXMlId" resultType="User" parameterType="string">
SELECT
*
FROM
puser
WHERE
userId = #{userId}
</select>
</mapper>

友情链接

springboot---->集成mybatis开发(一)的更多相关文章

  1. 在springboot中集成mybatis开发

    在springboot中利用mybatis框架进行开发需要集成mybatis才能进行开发,那么如何在springboot中集成mybatis呢?按照以下几个步骤就可以实现springboot集成myb ...

  2. springboot集成mybatis(二)

    上篇文章<springboot集成mybatis(一)>介绍了SpringBoot集成MyBatis注解版.本文还是使用上篇中的案例,咱们换个姿势来一遍^_^ 二.MyBatis配置版(X ...

  3. SpringBoot集成MyBatis的Bean配置方式

    SpringBoot集成MyBatis的Bean配置方式 SpringBoot是一款轻量级开发的框架,简化了很多原先的xml文件配置方式,接下来就介绍一下如何不适用XML来配置Mybatis spri ...

  4. 0120 springboot集成Mybatis和代码生成器

    在日常开发中,数据持久技术使用的架子使用频率最高的有3个,即spring-jdbc , spring-jpa, spring-mybatis.详情可以看我之前的一篇文章spring操作数据库的3个架子 ...

  5. SpringBoot集成MyBatis底层原理及简易实现

    MyBatis是可以说是目前最主流的Spring持久层框架了,本文主要探讨SpringBoot集成MyBatis的底层原理.完整代码可移步Github. 如何使用MyBatis 一般情况下,我们在Sp ...

  6. SpringBoot集成MyBatis小记

    SpringBoot集成MyBatis小记 参考MyBatis官网 1. 添加maven依赖 添加到pom.xml <dependency> <groupId>org.myba ...

  7. springboot集成mybatis(一)

    MyBatis简介 MyBatis本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation迁移到了google code,并且改名为MyB ...

  8. SpringBoot 集成Mybatis 连接Mysql数据库

    记录SpringBoot 集成Mybatis 连接数据库 防止后面忘记 1.添加Mybatis和Mysql依赖 <dependency> <groupId>org.mybati ...

  9. SpringBoot Mybatis整合(注解版),SpringBoot集成Mybatis(注解版)

    SpringBoot Mybatis整合(注解版),SpringBoot集成Mybatis(注解版) ================================ ©Copyright 蕃薯耀 2 ...

  10. SpringBoot集成Mybatis并具有分页功能PageHelper

    SpringBoot集成Mybatis并具有分页功能PageHelper   环境:IDEA编译工具   第一步:生成测试的数据库表和数据   SET FOREIGN_KEY_CHECKS=0;   ...

随机推荐

  1. CentOS下面磁盘扩容处理

    1. 给虚拟机增加一块硬盘: 过程不表 2. 增加了硬盘之后需要重启一下 查看磁盘 ls /dev/sd* 3. 使用  gdisk 处理磁盘 注意 这里面fdisk 貌似没法处理成 LVM 必须使用 ...

  2. JS 中的require 和 import 区别

    这两个都是为了JS模块化编程使用. 遵循规范 require 是 AMD规范引入方式 import是es6的一个语法标准,如果要兼容浏览器的话必须转化成es5的语法 调用时间 require是运行时调 ...

  3. Java设计模式之代理模式(静态代理和JDK、CGLib动态代理)以及应用场景

    我做了个例子 ,需要可以下载源码:代理模式 1.前言: Spring 的AOP 面向切面编程,是通过动态代理实现的, 由两部分组成:(a) 如果有接口的话 通过 JDK 接口级别的代理 (b) 如果没 ...

  4. SpringMvc+JavaConfig+Idea 基于JavaConfig搭建项目

    1.介绍 之前搭建SpringMvc项目要配置一系列的配置文件,比如web.xml,applicationContext.xml,dispatcher.xml.Spring 3.X之后推出了基于Jav ...

  5. ESLint的使用

    ESLint是在ECMAScript/JavaScript代码中识别和报告模式匹配的工具,它的目标是保证代码的一致性和避免错误.在许多方面,它和JSLint.JSHint相似,除了少数的例外: ESL ...

  6. Graham's Scan法求解凸包问题

    概念 凸包(Convex Hull)是一个计算几何(图形学)中的概念.用不严谨的话来讲,给定二维平面上的点集,凸包就是将最外层的点连接起来构成的凸多边型,它能包含点集中所有点的.严谨的定义和相关概念参 ...

  7. 【bzoj3132】 Sdoi2013—森林

    http://www.lydsy.com/JudgeOnline/problem.php?id=3123 (题目链接) 题意 给出$n$个点的森林,每个点有一个非负点权,$m$个操作.连接两个点,查询 ...

  8. 【bzoj3992】 SDOI2015—序列统计

    http://www.lydsy.com/JudgeOnline/problem.php?id=3992 (题目链接) 题意 集合${S}$中有若干个不超过${m}$的非负整数,问由这些数组成一个长度 ...

  9. 【bzoj2001】 Hnoi2010—City 城市建设

    http://www.lydsy.com/JudgeOnline/problem.php?id=2001 (题目链接) 题意 给出一张无向图,$m$组操作,每次修改一条边的权值,对于每次操作输出修改之 ...

  10. Dist

    Description 数据范围:\(1<=n<=10^5,1<=k<=18,1<=k_i<=10^7,\sum |s_i|<=3*10^5\) Soluti ...