spring boot ----> 和mybatis。。。
环境:
centos6.8,jdk1.8.0_172,maven3.5.4,spring boot1.5.15
1、使用maven命令:mvn dependency:tree查看mybatis-spring-boot-starter的依赖情况:

关注mybatis直接相关的jar包:
mybatis-spring-boot-autoconfigure-1.3.2.jar,mybatis-3.4.6.jar,mybatis-spring-1.3.2.jar
2、基本配置
1)工程结构:mapper和sql映射 分别放置在不同位置:
src/main/java/com/rui/mapper # mapper接口:XxxMapper.java src/main/resources/mapper #映射文件: XxxMapper.xml
2)配置文件:application.properties配置操作数据库key-value:
spring.datasource.url=jdbc:mysql://localhost:3306/你的数据库 spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.username=你的用户名 spring.datasource.password=你的密码 mybatis.mapper-locations=classpath:mapper/*.xml # sql映射文件位置 mybatis.type-aliases-package=com.rui.domain #实体类包名
3)注解配置:springboot启动类添加@MapperScan(basePackages="{p1,p2}")
注解在包 org.mybatis.spring.annotation 中
4)XxxMapper.xml:当在写类似于List<User> findAllUsers(); 的时候,在xml文件中,需要注意它的resultType的写法,根据官方文档的提示,这里只需要配置成User即可,即实体类类型,直接填入集合类型如List会导致错误。


5)mybatis拓展,分页和分页插件PageHelper的使用
假如使用MySQL数据库,一般写分页需要分成两个步骤:1、根据条件查询出总记录数;2、根据条件查询分页,使用MySQL的limit offset, rowsets分页查询出记录
PageHelper的stater:
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.2.5</version>
</dependency>6
starter的 依赖树

application.properties配置:
#pagehelper pagehelper.helperDialect=mysql pagehelper.reasonable=true 4 pagehelper.supportMethodsArguments=true pagehelper.params=count=countSql 6
关键代码:
import com.github.pagehelper.PageHelper;
// ①服务实现层
PageHelper.startPage(page, rows);
import com.github.pagehelper.PageInfo;
9 //②控制器层
List<User> userList = userService.selectByUser(user, page, rows);
result.addObject("pageInfo", new PageInfo<User>(userList));12
一个实例:场景:从数据库查询user表,把查询到的users分页。
后台代码:
控制器层
import org.springframework.stereotype.Controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import com.rui.service.UserService;
import com.rui.domain.User;
import java.util.List;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import com.github.pagehelper.PageInfo;
@Controller
@RequestMapping("/find")
public class UserController{
@Autowired
private UserService userService;
@RequestMapping(value="/page")
public ModelAndView findByPage(
@RequestParam(required=false,defaultValue="1") int pageNum ,
@RequestParam(required=false,defaultValue="3")int pageSize){
ModelAndView mav = new ModelAndView();
List<User> list = userService.getAllUsersByPage(pageNum,pageSize);
PageInfo pageInfo = new PageInfo(list);
mav.addObject("pageInfo",pageInfo);
mav.setViewName("third");
return mav;
}
}
服务实现层
package com.rui.userService.serviceImpl;
import java.util.List;
import com.rui.service.UserService;
import com.rui.domain.User;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.rui.mapper.UserMapper;
import com.github.pagehelper.PageHelper;
@Transactional
@Service
public class UserServiceImpl implements UserService{
@Autowired
private UserMapper userMapper;
@Override
public List<User> getAllUsersByPage(int pageNum, int pageSize){
PageHelper.startPage(pageNum, pageSize);
return userMapper.findAllUsers();
}
}
前台代码:
分页/分页导航页码
css:
ul{
;
;
}
.first li{
list-style:none;
float:left;
}
.first .pre{
border:1px black solid;
border-right:0px;
padding-left:15px;
padding-right:15px;
}
.first .next{
border:1px black solid;
border-left:0px;
padding-left:15px;
padding-right:15px;
}
.mid .second li{
border:1px black solid;
padding-left:15px;
padding-right:15px;
}
html:(thymeleaf做前台模板)
<table>
<thead>
<tr>
<th colspan="4">查询结果</th>
</tr>
<tr>
<th>ID</th>
<th>NAME</th>
<th>PWD</th>
<th>SEX</th>
</tr>
</thead>
<tbody>
<tr th:each="user : ${pageInfo.list}">
<td th:text="${user.uid}">1</td>
<td th:text="${user.name}">rr</td>
<td th:text="${user.pwd}">123</td>
<td th:text="${user.sex}">m</td>
</tr>
</tbody>
</table>
<br/>
<hr/>
<ul class="first">
<li class="pre" th:if="${pageInfo.hasPreviousPage}">
<a th:href="@{/find/page(pageNum=${pageInfo.prePage},pageSize=${pageInfo.pageSize})}">前一页</a>
</li>
<li class="mid" th:each="nav : ${pageInfo.navigatepageNums}">
<ul class="second">
<li th:if="${nav == pageInfo.pageNum}" th:text="${nav}">nav</li>
<li th:if="${nav != pageInfo.pageNum}">
<a th:text="${nav}" th:href="@{/find/page(pageNum=${nav},pageSize=${pageInfo.pageSize})}">nav</a>
</li>
</ul>
</li>
<li class="next" th:if="${pageInfo.hasNextPage}">
<a th:href="@{/find/page(pageNum=${pageInfo.nextPage},pageSize=${pageInfo.pageSize})}">下一页</a>
</li>
</ul>
效果是这样的:

1、导航页码navigatePageNums数据类型是数组,它的长度根据总页码数pages和导航页navigatePages的关系调整,navigatePages默认是8,可以自定义。导航页码显示的长度以8为界限调整。


如果需要在jsp页面显示navigatePageNums,可以这么干:
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<tr class="navigatePageNums">
<th>导航页码 【navigatepageNums(defaultValue)】</th>
<td>${fn:length(pageInfo.navigatepageNums)}</td>
</tr>
note:
①include标签引用sql标签通过 refid=""
②application.properties配置mybatis的两个属性:
1、mapper.xm文件的位置
2、实体类的别名配置
③mapper.xml文件:namespace配置
④mapper扫描: 用@MapperScan在启动类上,指定Mapper接口的包名 ??? 使用@Mapper不起作用
spring boot ----> 和mybatis。。。的更多相关文章
- Spring Boot 整合 Mybatis 实现 Druid 多数据源详解
摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢! “清醒时做事,糊涂时跑步,大怒时睡觉,独处时思考” 本文提纲一.多数据源的应用场景二.运行 sp ...
- 使用intelliJ创建 spring boot + gradle + mybatis站点
Spring boot作为快速入门是不错的选择,现在似乎没有看到大家写过spring boot + gradle + mybatis在intellij下的入门文章,碰巧.Net同事问到,我想我也可以写 ...
- Spring Boot整合Mybatis并完成CRUD操作
MyBatis 是一款优秀的持久层框架,被各大互联网公司使用,本文使用Spring Boot整合Mybatis,并完成CRUD操作. 为什么要使用Mybatis?我们需要掌握Mybatis吗? 说的官 ...
- Spring boot整合Mybatis
时隔两个月的再来写博客的感觉怎么样呢,只能用“棒”来形容了.闲话少说,直接入正题,之前的博客中有说过,将spring与mybatis整个后开发会更爽,基于现在springboot已经成为整个业界开发主 ...
- Spring boot教程mybatis访问MySQL的尝试
Windows 10家庭中文版,Eclipse,Java 1.8,spring boot 2.1.0,mybatis-spring-boot-starter 1.3.2,com.github.page ...
- spring boot 实现mybatis拦截器
spring boot 实现mybatis拦截器 项目是个报表系统,服务端是简单的Java web架构,直接在请求参数里面加了个query id参数,就是mybatis mapper的query id ...
- spring boot 整合 mybatis 以及原理
同上一篇文章一样,spring boot 整合 mybatis过程中没有看见SqlSessionFactory,sqlsession(sqlsessionTemplate),就连在spring框架整合 ...
- Spring Boot集成MyBatis开发Web项目
1.Maven构建Spring Boot 创建Maven Web工程,引入spring-boot-starter-parent依赖 <project xmlns="http://mav ...
- 详解Spring Boot集成MyBatis的开发流程
MyBatis是支持定制化SQL.存储过程以及高级映射的优秀的持久层框架,避免了几乎所有的JDBC代码和手动设置参数以及获取结果集. spring Boot是能支持快速创建Spring应用的Java框 ...
- Spring Boot 整合MyBatis(1)
这篇文章介绍如何在Spring boot中整合Mybatis,其中sql语句采用注解的方式插入.后续文章将会介绍,如何使用xml方式. SSM SSH框架已经满足轻量级这个需求了,但是对于开发人员而言 ...
随机推荐
- QT笔记之内存管理
转载:https://blog.csdn.net/myjqc/article/details/8569196 (链接错误解决办法) 我们都知道在C++中,new和delete是成对出现的,那么在QT中 ...
- Kettle 连接 Oracle 问题总结
一. Driver class 'oracle.jdbc.driver.OracleDriver' could not be found, make sure the 'Oracle' driver ...
- Nginx 安装及配置
目录 概念 安装 配置文件 主要文件位置 注意点 Nginx运行 FAQ Q1:nginx: [error] open() "/usr/local/var/run/nginx.pid&quo ...
- Markdon 作图语法 CSDN
插入甘特图 gantt dateFormat YYYY-MM-DD title Adding GANTT diagram functionality to mermaid section 现有任务 已 ...
- git 如何revert指定范围内的commit并且只生成一个新的commit?
答:一共分成两步 一. revert多个commit并生成多个新的commit git revert <old commit>^..<new commit> 二. 使用reba ...
- linux基础之程序包管理(rpm,yum)
一.rpm 安装:rpm { -i | --install } [ install-options ] PACKAGE_FILE... -v: 显示安装时的详细信息 -vv: 显示许多难以阅读的调试信 ...
- aria2的下载配置
aria2的命令行命令是: aria2c 一种方式: aria2c "http://host/file.zip" 如同wget 第二种方式: rpc server方式:
- sql server查看用户权限
System.ServiceModel.FaultException: Server error. Detail: The EXECUTE permission was denied on the o ...
- Ubuntu关机时间过长,总是停在logo界面
有时候我们总能遇到ubuntu关机的时候卡住,无法关机,一查看发现是" a stop job is running..." 然后后面接着一串等待时间. 这时候我们需要修改一下sys ...
- JOISC 2014 邮戳拉力赛(基础DP)
题意 https://loj.ac/problem/2878 思路 真的神仙题,想到就很好写,想不到就写不出来. 肯定只能一个一个邮戳按顺序分析.首先,将取一枚邮戳的路径分为四种: 上行 \(\rig ...