当前位置: 首页 > news >正文

郑州有名的设计公司武汉seo关键字推广

郑州有名的设计公司,武汉seo关键字推广,凡科平台网站怎么建设,网络门店管理系统1、查看项目中是否导入mybatisPlus的jar包 2、servie 层和实现类要集成mybatisPlus service 继承IService<> 实现类中要继承IService的实现类ServiceImpl<mapper,实体类> 3、如果想要mapper中的一些方法&#xff0c;mapper 要继承BaseMapper<实体类> 4、在实…

1、查看项目中是否导入mybatisPlus的jar包

2、servie 层和实现类要集成mybatisPlus

service 继承IService<>

在这里插入图片描述实现类中要继承IService的实现类ServiceImpl<mapper,实体类>

在这里插入图片描述

3、如果想要mapper中的一些方法,mapper 要继承BaseMapper<实体类>

在这里插入图片描述

4、在实现类中实现方法,不需要在xml中写一个方法了,常用的方法

总结如下:

【1】分页

参数1是分页起始位置,一般是1,参数2:结束位置,    一般都是前端传过来的,查询的数量
Page<LandLossAllowance> page1 = new Page<LandLossAllowance>(参数1,参数2);
LambdaQueryWrapper<LandLossAllowance> queryWrapper = new LambdaQueryWrapper<>();
条件 eq 指的是相等
queryWrapper.eq(LandLossAllowance::getCountrySide,landLossAllowanceOption.getCountrySide());
执行page方法 page(参数1,参数2)参数1:上面的new的分页对象,参数2是lambda表达式查询条件
IPage<LandLossAllowance> iPage = page(page1, queryWrapper);

(一)PageHelper和IPage区别: 

使用方法:

PageHelper.startPage()然后后边写sql就可以。 紧接着的一个sql起作用。
IPage则需要在dao层传入IPage的实现类Page对象,该对象实现了IPage。

区别:

PageHelper内部原理是将传入的页码和条数赋值给了Page对象,保存到了一个本地线程ThreadLoacl中,然后会进入Mybatis的拦截器中。
    然后再拦截器中获取本地线程中保存的分页的参数。最后再将这写分页参数和原本的sql以及内部定义好的sql进行拼接完成sql的分页处理。
    中间会进行判断该sql 的类型是查询还是修改操作。如果是查询才会进入分页的逻辑并判断封装好的Page对象是否是null,null则不分页,否则分页。

IPage内部原理也是基于拦截器,但是这个拦截的是方法以及方法中的参数,这个也会判断是否是查询操作。如果是查询操作,才会进入分页的处理逻辑。
进入分页逻辑处理后,拦截器会通过反射获取该方法的参数进行判断是否存在IPage对象的实现类。如果不存在则不进行分页,存在则将该参数赋值给IPage对象。
然后进行拼接sql的处理完成分页操作。
但是使用IPage需要注入一个bean拦截器交给spring进行管理。如下。否则不会进行拦截。

使用Ipage之后,需要注入一些配置:

@Configuration
@MapperScan(value={"com.XX.**.mapper*"})
public class MybatisPlusConfig {/*** 分页插件*/@Beanpublic PaginationInterceptor paginationInterceptor() {// 设置sql的limit为无限制,默认是500return new PaginationInterceptor().setLimit(-1);}
}

(二)常用的lambda表达式的一些定义

在这里插入图片描述

com.baomidou.mybatisplus.core.conditions.query.QueryWrapper是MybatisPlus框架构造查询条件常用的对象

使用lambda表达式写法更为清晰,简洁:

 QueryWrapper<User> queryWrapper = new QueryWrapper<>();queryWrapper.lambda().eq(User::getName,"aa");queryWrapper.lambda().ge(User::getAge,20);

默认情况下多个条件是and连接:上述写法对应的SQL为:where name like '%aa%' and age >= 20

如果要使用or连接的话,方法如下:

queryWrapper.lambda().and(wq->{wq.like(User::getName,"aa");wq.or().like(User::getName,"bb);
});

这里引申下我遇到的一个场景:需要or连接的是一个集合内的所有元素:

List<String> nameList = Lists.newArrayList("aa","bb","cc");
String firstName = nameList.get(0);
nameList.remove(0);
queryWrapper.lambda().and(wq->{wq.like(User::getName,firstName);for(String name : nameList){wq.or().like(User::getName,name);}
});
http://www.wooajung.com/news/26527.html

相关文章:

  • 免费建网站.com的区别宁波seo深度优化平台
  • wordpress加载不同模板简述影响关键词优化的因素
  • 做外贸在什么网站上比较好营销活动怎么做吸引人
  • 网站产品标签文章标签怎么做深圳seo网络推广
  • 上海网络营销团队合作河南seo和网络推广
  • 网站建设 沈阳广告公司推广平台
  • 南昌网站开发培训班品牌营销策划有限公司
  • 徐州专业网站制作公司国外seo大神
  • 南昌优化网站分析网络推广公司服务内容
  • 网站建设课程毕设电商培训机构推荐
  • 张家港网站建设门店企业官网定制设计
  • 一个做网站的公司年收入济南网站优化排名
  • 推荐几个色情图片网站推广方案的推广内容怎么写
  • 太原网站制作开发seo网站推广教程
  • 网站优化垂直化好还是扁平化好seo是什么?
  • 网站优化要从哪些方面做公司在百度怎么推广
  • cdr做网站分辨率博客网站登录入口
  • 接单网个人接单企业新网站seo推广
  • 如何把做的网站与域名连接石家庄新闻最新消息
  • 合肥市房产信息网官网优化设计七年级下册语文答案
  • python 网站开发实例教程网络营销手段有哪些方式
  • 网站开发三层在线服务器网站
  • 可以免费建立网站吗如何让新网站被收录
  • 广东门户网站建设中国站免费推广入口
  • 网站制作老了舆情管理
  • 天津做网站的网络公司如何提升网站搜索排名
  • 建网站推广淘宝店seo优化就业前景
  • 模板做的网站如何下载地址百度代理公司
  • 影视网站建设搜索引擎推广是什么意思
  • 东营专业网站建设公司排行宁德市政府