环境:

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的使用

官网:https://github.com/abel533

假如使用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。。。的更多相关文章

  1. Spring Boot 整合 Mybatis 实现 Druid 多数据源详解

    摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢! “清醒时做事,糊涂时跑步,大怒时睡觉,独处时思考” 本文提纲一.多数据源的应用场景二.运行 sp ...

  2. 使用intelliJ创建 spring boot + gradle + mybatis站点

    Spring boot作为快速入门是不错的选择,现在似乎没有看到大家写过spring boot + gradle + mybatis在intellij下的入门文章,碰巧.Net同事问到,我想我也可以写 ...

  3. Spring Boot整合Mybatis并完成CRUD操作

    MyBatis 是一款优秀的持久层框架,被各大互联网公司使用,本文使用Spring Boot整合Mybatis,并完成CRUD操作. 为什么要使用Mybatis?我们需要掌握Mybatis吗? 说的官 ...

  4. Spring boot整合Mybatis

    时隔两个月的再来写博客的感觉怎么样呢,只能用“棒”来形容了.闲话少说,直接入正题,之前的博客中有说过,将spring与mybatis整个后开发会更爽,基于现在springboot已经成为整个业界开发主 ...

  5. 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 ...

  6. spring boot 实现mybatis拦截器

    spring boot 实现mybatis拦截器 项目是个报表系统,服务端是简单的Java web架构,直接在请求参数里面加了个query id参数,就是mybatis mapper的query id ...

  7. spring boot 整合 mybatis 以及原理

    同上一篇文章一样,spring boot 整合 mybatis过程中没有看见SqlSessionFactory,sqlsession(sqlsessionTemplate),就连在spring框架整合 ...

  8. Spring Boot集成MyBatis开发Web项目

    1.Maven构建Spring Boot 创建Maven Web工程,引入spring-boot-starter-parent依赖 <project xmlns="http://mav ...

  9. 详解Spring Boot集成MyBatis的开发流程

    MyBatis是支持定制化SQL.存储过程以及高级映射的优秀的持久层框架,避免了几乎所有的JDBC代码和手动设置参数以及获取结果集. spring Boot是能支持快速创建Spring应用的Java框 ...

  10. Spring Boot 整合MyBatis(1)

    这篇文章介绍如何在Spring boot中整合Mybatis,其中sql语句采用注解的方式插入.后续文章将会介绍,如何使用xml方式. SSM SSH框架已经满足轻量级这个需求了,但是对于开发人员而言 ...

随机推荐

  1. QT笔记之内存管理

    转载:https://blog.csdn.net/myjqc/article/details/8569196 (链接错误解决办法) 我们都知道在C++中,new和delete是成对出现的,那么在QT中 ...

  2. Kettle 连接 Oracle 问题总结

    一. Driver class 'oracle.jdbc.driver.OracleDriver' could not be found, make sure the 'Oracle' driver ...

  3. Nginx 安装及配置

    目录 概念 安装 配置文件 主要文件位置 注意点 Nginx运行 FAQ Q1:nginx: [error] open() "/usr/local/var/run/nginx.pid&quo ...

  4. Markdon 作图语法 CSDN

    插入甘特图 gantt dateFormat YYYY-MM-DD title Adding GANTT diagram functionality to mermaid section 现有任务 已 ...

  5. git 如何revert指定范围内的commit并且只生成一个新的commit?

    答:一共分成两步 一. revert多个commit并生成多个新的commit git revert <old commit>^..<new commit> 二. 使用reba ...

  6. linux基础之程序包管理(rpm,yum)

    一.rpm 安装:rpm { -i | --install } [ install-options ] PACKAGE_FILE... -v: 显示安装时的详细信息 -vv: 显示许多难以阅读的调试信 ...

  7. aria2的下载配置

    aria2的命令行命令是: aria2c 一种方式: aria2c "http://host/file.zip" 如同wget 第二种方式: rpc server方式:

  8. sql server查看用户权限

    System.ServiceModel.FaultException: Server error. Detail: The EXECUTE permission was denied on the o ...

  9. Ubuntu关机时间过长,总是停在logo界面

    有时候我们总能遇到ubuntu关机的时候卡住,无法关机,一查看发现是" a stop job is running..." 然后后面接着一串等待时间. 这时候我们需要修改一下sys ...

  10. JOISC 2014 邮戳拉力赛(基础DP)

    题意 https://loj.ac/problem/2878 思路 真的神仙题,想到就很好写,想不到就写不出来. 肯定只能一个一个邮戳按顺序分析.首先,将取一枚邮戳的路径分为四种: 上行 \(\rig ...