SpringBoot整合Mybatis,使用通用mapper和PageHelper进行分页
上节介绍了如何整合Security,这节就说下如何再Springboot下使用持久层框架mybatis和牛人封装的通用mapper与mybatis的整合,直接进入正题吧!
1.首先引入我们需要的依赖:
2.mybatis的配置
配置myabtis有两种方式,一是通过javaconfig配置还有一种直接使用Springbot的配置文件进行设置:mybatis.mapper-locations=classpath:mapper/**/*.xml,但是我这里使用的是mybatis的注解方式所以连这个都不需要配置,另外还需要配置mapUnderscoreToCamelCase这个属性,这是用来我们做查或者新增的时候,mybatis自动会把我们的实体类按照驼峰格式转为数据库里面的下划线格式,好处就是不要写resultmap了。
3.通用mapper的集成
首先我们需要定义一个我们自己的通用mapper接口继承封装好的两个接口(都在tk里面)
接下来我将我们对应的mapper继承这个mapper,使用mapper注解
这里面我只写了一个deletes方法,用来进行批量删除的,但是这个mapper已经具备增删改查的所有功能,其中FrameCode是我们与数据表中对应的实体。既然我们已经有了mapper我们就看如何使用他们了
我们再service层里面进行了了对mapper的调用,我们可以看出selectByExample,insert,updateByPrimaryKey这些方法我们再mapper中都没有定义,说明我们可以直接使用通用mapper里面的方法,我们不需要写哪些重复的增删改查代码了。对于mapper里面封装的crud方法,我这里值=只着重讲一个查询(模糊查询),也许是使用的最常见的,也是mapper里面使用的最麻烦的一个方法,我这里对他进行了一个简单的封装:
4.原始的mapper里面的模糊查询方法
可以看出这里需要准备criteria进行创建模糊查询,这里还只是模糊查询一个字段,如果后续增加了字段,还需要不断的再这里添加,是不是很麻烦,而且也不好移植,所以我这里就对他进行了简单的封装,用的是反射,自从知道了反射,好多功能上面都用上了,确实很方便
到这里为止,已经将mybatis的集成和通用mapper的使用介绍完毕,最后再介绍一个插件PageHelper的使用
5.PageHelper的集成与使用
我们再做项目时,避免不了会进行分页,我们会自己进行去下分页语句,mysql会使用limit,sqlserver使用top,oracle使用rownumber实现,会不会觉得很不方便,今天我为给大家介绍一下PageHelper这个插件在Springboot中的使用
首先引入插件的依赖
接着对pagehelper进行配置,这里也有两种方式:我都贴出来
最后介绍下如何在项目中使用:
1.先从请求参数中获取到pageCurrent(当前页),pageSize(页面大小),因为我前端用的时bjui框架,所以在后台接收到的是这两个字段。
2.我们将请求参数 PageHelper.startPage(pageCurrent,pageSize);放到这里面
3.再查询我们需要的数据,例如这样:List entitys = service.getAll(entity);
4.最后再将数据封装到PageInfo pageInfo=new PageInfo(entitys);这里,
pageInfo里面存储了我们想要的数据,total,start,limit,size都在里面,我们只需要去除我们关心的数据就好了,我这里值取出了数据的总记录数pageInfo.getTotal(),总的代码记录如下
感谢大家能看到这里,文中讲的不正确的地方,欢迎在下方留言,我会及时修正。
欢迎大家关注我的公众号,会不定时更新技术干货。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Java并发编程笔记之CopyOnWriteArrayList源码分析
并发包中并发List只有CopyOnWriteArrayList这一个,CopyOnWriteArrayList是一个线程安全的ArrayList,对其进行修改操作和元素迭代操作都是在底层创建一个拷贝数组(快照)上进行的,也就是写时拷贝策略。 我们首先看一下CopyOnWriteArrayList的类图有哪些属性和方法,如下图所示: 如上,CopyOnWriteArrayList的类图,每个CopyOnWriteArrayList对象里面有一个array数组对象用来存放具体元素,ReentrantLock独占锁对象用来保证同时只有一个线程对array进行修改,这里只要记得ReentrantLock是独占锁,同时只有一个线程可以获取就可以了。 那么问题来了,如果让我们自己去做一个写时拷贝的线程安全的List,我们会怎么做,要考虑哪些要点? 1.list何时初始化,初始化list元素个数为多少,list是有限大小? 2.如何保证线程安全,比如多个线程进行读写时候,如果保证是线程安全的? 3.如何使用迭代器遍历list时候的数据一致性? 那么我们就进入CopyOnWriteArrayLis...
- 下一篇
C++程序设计基础(7)位运算
注:读《程序员面试笔记》笔记总结 1.知识点 运算 符号 说明 与 & 有0为0,都1为1 或 | 由1为1,都0为0 非(取反) ~ 0变1,1变0 异或 ^ 同为0,异为1 左移 << 高位移除,低位补零 右移 >> 低位移除,高位补0 1.1异或的性质 1 a^a==0 2 0^a==a 3 a^b^b==b^a^b==a 2.面试题 2.1不使用变量交换两个值 1 //method one 2 a = a - b;//save b message 3 b = a + b;//b= old a 4 a = b - a; 5 //method two 6 a = a ^ b; 7 b = a ^ b;//b= old a 8 a = a ^ b; 提示:利用位的运算性质 2.2计算二进制的1的个数 1 //method one 2 for ( count = 0; num != 0; num=num >> 1) { 3 if (num & 1) { 4 count++; 5 } 6 } 7 //method two 8 for (...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- CentOS8安装Docker,最新的服务器搭配容器使用
- CentOS7安装Docker,走上虚拟化容器引擎之路
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- Docker安装Oracle12C,快速搭建Oracle学习环境
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS7,CentOS8安装Elasticsearch6.8.6