如何在Spring名目中顺利性能MP-MyBatis (如何在springer上下载文献)
在Spring名目中集成MP,须要启动以下性能:
1.引入依赖:在名目标pom.xml文件中参与MP相关依赖,例如:```xml<dependency><groupId>com.baomidou</groupId><artifactId>-plus-boot-starter</artifactId><version>最新版本号</version></dependency>```2.性能数据源:在SpringBoot的性能文件中性能数据源,例如:```propertiesspring.datasource.driver-class-name=com..jdbc.Driverspring.datasource.url=jdbc:mysql://localhost:3306/database_namespring.datasource.username=usernamespring.datasource.pass=password```3.性能MyBatis-Plus:在SpringBoot的性能文件中参与以下性能:```properties#开启MP智能填充性能mybatis-plus.global-config.db-config.auto-fill=true#性能MP代码生成器mybatis-plus.generator-config.package-config=com.examplemybatis-plus.generator-config.strategy-config.table-prefix=tb_mybatis-plus.generator-config.strategy-config.entity-lombok-model=true```4.编写实体类和Mer接口:创立对应数据库表的实体类,并经常使用注解来性能表名、字段名等信息;创立Mapper接口,承袭`BaseMapper`接口,并经常使用注解来性能映射相关,例如:```@Entity@Table(name="user")publicclassUser{@Id@GeneratedValue(strategy=GenerationType.IDENTITY)privateLongid;privateStringusername;privateIntegerage;//...省略getter和setter方法}@MapperpublicinterfaceUserMapperextendsBaseMapper<User>{//...定义其余自定义查问方法}```5.经常使用MP性能:在Service层或其余业务逻辑层中经常使用MP提供的性能,例如分页查问、条件查问等操作。可以间接调用`BaseMapper`中的方法,或许经常使用MP提供的封装好的方法,例如:```java@ServicepublicclassUserServiceImplimplementsUserService{@AutowiredprivateUserMapperuserMapper;@OverridepublicList<User>getAllUsers(){returnuserMapper.selectList(null);}@OverridepublicUsergetUserById(Longid){returnuserMapper.selectById(id);}@OverridepublicvoidsaveUser(Useruser){userMapper.insert(user);}@OverridepublicvoidupdateUser(Useruser){userMapper.updateById(user);}@OverridepublicvoiddeleteUser(Longid){userMapper.deleteById(id);}}```以上是MP和Spring集成的基本色能和经常使用步骤。经过性能数据源、MP的智能填充和代码生成器等性能,可以极大地简化数据库操作的开发。同时,MP还提供了丰盛的查问、降级、删除等方法,可以极速成功经常出现的数据库操作。
SpringBoot进阶之Mybatis分页插件
大家好,一直以来我都本着 用最通俗的话理解核心的知识点, 我认为所有的难点都离不开「基础知识」 的铺垫
「大佬可以绕过 ~」
如果你是一路看过来的,很高兴你能够耐心看完。之前带大家学了 Springboot 基础部分,对基本的使用有了初步的认识, 接下来的几期内容将会带大家进阶使用,会先讲解基础中间件 的使用和一些场景的应用,或许这些技术你听说过,没看过也没关系,我会带大家一步一步的入门,耐心看完你一定会有收获 ~
上期带大家学习了 Springboot 中如何集成redis 以及它的一个基本使用, 本期将带大家学习mybatis 的一个分页插件 的使用,同样的,我们集成到Springboot 中。最近github可能会被墙,所以我把源码放到了国内gitee上,本节我们依然使用上期的代码
分页好比你买的书一样,它内容多了,总不能放一页吧,一页也放不下,所以得分页,第一页翻完就翻第二页,所以很好理解。在程序中,一般分页常用于列表的接口比如用户列表、文章列表等等,而列表项的数据一般都返回很简单的数据用于前端展示,详情页一般会展示比较全的一个数据,所以大家写接口的时候可以注意下,不要全部返回数据。有的详情是要带着权限去查询的,如果列表就返回了全部数据,万一对方是个懂技术的,不就曝光了表里的全部数据了。
我们再说一下分页的算法, 分页里主要有两个变量一个是 page , 另一个是pageSize ,一般由前端传过来,服务端会接收这两个数值,在接收的时候要判断一下,如果对方为空或者0,你可以设置一个基础值比如page=1 , pageSize=10 ,不至于用户看到的是空列表
其实分页,在 sql 中就可以做分页功能了,之前讲mysql 没给大家介绍,主要是想结合这一节一起讲。那么sql 怎么做分页呢?以之前的用户角色列表为例:
同样的,主要是 limit , offset 这两个值, 第一个很好理解,限制数量,就是一页多少个数据,第二个也很好理解,位移,就是向下位移多少条数据,一般可以通过如下公式计算:
很简单的数学题,不要说不会 ~
好,有了以上基础,大家可以自行试一下,在 ** 写一下试试,这种方式也是可以的, 下面给大家介绍个神器
同样的,修改一下我们的
这里直接帮大家封装好,因为一般列表项数据主要涉及几个属性,list(数据) , total(总条数) , pageSize(一页多少条) , pageNum(当前第几页) ,主要涉及这几项,因为前端一般也会根据这几个值,进行列表,页码的一个展示,好,我们直接看代码:
然后,我们去调用它, 修改我们之前写的列表:
请求成功后会返回如下:
其实它的原理,也是对 sql 进行了改写,进行了sql 查询, 底层主要依赖mybatis 的拦截器进行实现的, 这里不给大家过多深入讲解,后边会给大家介绍,我们先熟练掌握它的一个基本使用。
本期就到这里结束了,总结一下,本节主要带大家学习了 sql 如何进行分页查询和介绍了mybatis 分页插件 的基本使用,建议大家多去试着写写
在 springboot 中进行单独的 mybatis 单元测试
使用普通的@SpringBootTest进行单元测试时会将整个应用都启动,和正常启动工程没什么区别。 非常耗时。 如下,启动测试。 将web层也启动了。 事实上根本不需要启动这个。 我们只需要启动dao就行了。 在这里我们使用mybatis-spring-boot-starter-test这个依赖 测试例子 打印sql 1、: Unable to find a @SpringBootConfiguration, you need to use @ContextConfiguration or @SpringBootTest(classes=...) with your test 需要和springboot main方法放到同一级包下 2、Caused by: : Failed to instantiate []: Factory method dataSource threw exception; nested exception is $DataSourceBeanCreationException: Failed to determine a suitable driver class 若依工程引入这个真的有点难,推荐还是使用@SpringBootTest的方式 普通单数据源请配置如下的形式;否则单元测试启动报错url attribute is not specified and no embedded datasource could be configured. 有多个数据源时才去配置这样,;
免责声明:本文转载或采集自网络,版权归原作者所有。本网站刊发此文旨在传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及版权、内容等问题,请联系本网,我们将在第一时间删除。同时,本网站不对所刊发内容的准确性、真实性、完整性、及时性、原创性等进行保证,请读者仅作参考,并请自行核实相关内容。对于因使用或依赖本文内容所产生的任何直接或间接损失,本网站不承担任何责任。