Mybatis-plus的使用
接口mapper需要继承BaseMapper<要操作的类>外加@Mapper
mport org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
@Mapper
public interface AdminUserMapper extendsBaseMapper<AdminUserEntity> {
AdminUserEntity:
@TableName("openapi_admin_user")
@Data
public class AdminUserEntity extends BaseEntity {
@TableId("user_id")
private Long userId;
private String userName;
private String userPassword;
private String userType;
private String status;
private String telephone;
private String isInitPwd;
private Long renterId;
/**
* 登录用户 及新增用户的创建人
*/
private String createBy;
BaseEntity:
@Data
@ApiModel("基础实体类")
public abstract class BaseEntity { @ApiModelProperty(value = "创建人")
private String createBy; @ApiModelProperty(value = "更新人")
private String updateBy; @ApiModelProperty(value = "更新时间")
@JsonSerialize(using = JsonDateSerializer.class)
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date dateUpdated; @ApiModelProperty(value = "创建时间")
@JsonSerialize(using = JsonDateSerializer.class)
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date dateCreated; }
1:如果有涉及到输入框的查询时,分页
Controller:
@ApiOperation("查询角色列表")
@PostMapping("/list")
public ResponseDto<Page<RoleResponse>> listRoles(@RequestBody @Valid PageWrapper<RoleRequest> pageRequest) {
log.info("/roles/list start");
log.info("【/roles/list】调用roleService层入参: " + pageRequest);
Page page = new Page(pageRequest.getCurrent(), pageRequest.getSize());
if(pageRequest.getDataBody() == null) {
throw new ServiceException(ResponseCode.ValidationError.getCode(), "缺少参数dataBody");
}
Page<RoleResponse> list = roleService.selectRoleListByCondition(page, pageRequest.getDataBody());
log.info("/roles/list end");
return ResponseUtil.success(list);
}
PageWrapper:
*/
@Data
public class PageWrapper<T> {
@NumberFormat
private int current = 1;
private int size = 10;
private int total;
private int pages; @Valid
private T dataBody;
}
Repository:(无排序)
*/
public Page<RoleResponse> selectRoleListByCondition(Page pageRequest, RoleRequest request) {
List<RoleResponse> responseList = new ArrayList<>(0); Pagination page = getPageParam(pageRequest); // condition
RoleEntity param = new RoleEntity();
EntityWrapper<RoleEntity> wrapper = new EntityWrapper<>(param);
wrapper.like(StringUtils.isNotBlank(request.getRoleName()), "aa.role_name", request.getRoleName());
wrapper.ge(request.getStart() != null, "aa.date_created", request.getStart() + " 00:00:00");
/* if (StringUtils.isNotEmpty(request.getEnd())) {
wrapper.le("aa.date_updated", request.getEnd() + " 23:59:59");
}*/
wrapper.le(request.getEnd() != null,"aa.date_created", request.getEnd() + " 23:59:59");
wrapper.eq(request.getRoleId() != null, "aa.role_id", request.getRoleId());
log.info("selectRoleListByCondition:: {}", wrapper.getSqlSegment()); List<RoleResponse> entities = null;
try {
// 查询角色列表
entities = roleMapper.selectRolesByPage(page, wrapper);
if (CollectionUtils.isEmpty(entities)) {
log.warn("No roles were found.");
return buildResponse(page, responseList);
}
private Page<RoleResponse> buildResponse(Pagination page, List<RoleResponse> responses) {
Page<RoleResponse> result = new Page<>(page.getCurrent(), page.getSize());
result.setRecords(responses);
result.setTotal(page.getTotal());
return result;
}
Repository(排序):
public List<UserResponse> listUsers(UserRequest request) {
AdminUserEntity userEntity = new AdminUserEntity();
EntityWrapper<AdminUserEntity> ew = new EntityWrapper<>(userEntity);
ew.eq("status", CommonFlagEnum.Yes.getCode()).eq(StringUtils.isNotBlank(request.getCompanyName()),
"company_name", request.getCompanyName()).eq(StringUtils.isNotBlank(request.getUserType()),
"user_type", request.getUserType()).eq(StringUtils.isNotBlank(request.getUserName()),
"um_id", request.getUserName()).like(StringUtils.isNotBlank(request.getUserName()),
"user_name", request.getUserName());
//排序列
List<String> orderColumns = new ArrayList<>();
orderColumns.add("date_created");
ew.orderDesc(orderColumns);
log.info("sql: {}, {}", ew.getSqlSelect(), ew.getSqlSegment());
try {
List<AdminUserEntity> entities = userMapper.selectList(ew);
Mapper:
List<RoleResponse> selectRolesByPage(Pagination pagination, @Param("ew") Wrapper<RoleEntity> wrapper);
xml:
<select id="selectRolesByPage" resultType="com.paic.ocss.gateway.model.dto.role.RoleResponse">
SELECT
aa.role_id,
aa.role_name,
aa.STATUS,
aa.date_created,
aa.create_by,
aa.date_updated,
aa.update_by,
aa.role_desc,
bb.resource_ids
FROM
openapi_admin_role aa
LEFT JOIN ( SELECT GROUP_CONCAT( r.resource_id ) resource_ids, r.role_id FROM
openapi_admin_role_resource_mapping r GROUP BY r.role_id ) bb ON aa.role_id = bb.role_id
<where>
${ew.sqlSegment}
</where>
order by date_created desc </select>
2:如果没有涉及到输入框的查询时,分页,而是简单的增,删,改,查:
public void modify(UserModify userRequest) {
AdminUserEntity userEntity = new AdminUserEntity();
userEntity.setUserId(userRequest.getUserId());
if (StringUtils.isNotBlank(userRequest.getTelephone())) {
userEntity.setTelephone(userRequest.getTelephone());
}
if (StringUtils.isNotBlank(userRequest.getUserName())) {
userEntity.setUserName(userRequest.getUserName());
}
if (StringUtils.isNotBlank(userRequest.getStatus())) {
userEntity.setStatus(userRequest.getStatus());
}
if (userRequest.getRenterId() != null) {
userEntity.setRenterId(userRequest.getRenterId());
}
String loginAccount = SecurityUtils.getSubject().getPrincipal().toString();
userEntity.setUpdateBy(loginAccount);
if (CommonFlagEnum.Yes.getCode().equals(userRequest.getIsInitPwd())) {
//存储到db的密码
userEntity.setUserPassword(SHA256Util.getSHA256StrJava(DEFAULT_PASSWORD));
} else if(userRequest.getUserPassword() != null){
userEntity.setUserPassword(SHA256Util.getSHA256StrJava(userRequest.getUserPassword()));
}
//SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")
//userEntity.setDateUpdated(format.format(new Date()));
userEntity.setDateUpdated(new Date());
try {
int count = userMapper.updateById(userEntity);



Mybatis-plus的使用的更多相关文章
- 【分享】标准springMVC+mybatis项目maven搭建最精简教程
文章由来:公司有个实习同学需要做毕业设计,不会搭建环境,我就代劳了,顺便分享给刚入门的小伙伴,我是自学的JAVA,所以我懂的.... (大图直接观看显示很模糊,请在图片上点击右键然后在新窗口打开看) ...
- Java MyBatis 插入数据库返回主键
最近在搞一个电商系统中由于业务需求,需要在插入一条产品信息后返回产品Id,刚开始遇到一些坑,这里做下笔记,以防今后忘记. 类似下面这段代码一样获取插入后的主键 User user = new User ...
- [原创]mybatis中整合ehcache缓存框架的使用
mybatis整合ehcache缓存框架的使用 mybaits的二级缓存是mapper范围级别,除了在SqlMapConfig.xml设置二级缓存的总开关,还要在具体的mapper.xml中开启二级缓 ...
- 【SSM框架】Spring + Springmvc + Mybatis 基本框架搭建集成教程
本文将讲解SSM框架的基本搭建集成,并有一个简单demo案例 说明:1.本文暂未使用maven集成,jar包需要手动导入. 2.本文为基础教程,大神切勿见笑. 3.如果对您学习有帮助,欢迎各种转载,注 ...
- mybatis plugins实现项目【全局】读写分离
在之前的文章中讲述过数据库主从同步和通过注解来为部分方法切换数据源实现读写分离 注解实现读写分离: http://www.cnblogs.com/xiaochangwei/p/4961807.html ...
- MyBatis基础入门--知识点总结
对原生态jdbc程序的问题总结 下面是一个传统的jdbc连接oracle数据库的标准代码: public static void main(String[] args) throws Exceptio ...
- Mybatis XML配置
Mybatis常用带有禁用缓存的XML配置 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE ...
- MyBatis源码分析(一)开篇
源码学习的好处不用多说,Mybatis源码量少.逻辑简单,将写个系列文章来学习. SqlSession Mybatis的使用入口位于org.apache.ibatis.session包中的SqlSes ...
- (整理)MyBatis入门教程(一)
本文转载: http://www.cnblogs.com/hellokitty1/p/5216025.html#3591383 本人文笔不行,根据上面博客内容引导,自己整理了一些东西 首先给大家推荐几 ...
- MyBatis6:MyBatis集成Spring事物管理(下篇)
前言 前一篇文章<MyBatis5:MyBatis集成Spring事物管理(上篇)>复习了MyBatis的基本使用以及使用Spring管理MyBatis的事物的做法,本文的目的是在这个的基 ...
随机推荐
- 为什么说是时候拥抱.NET CORE了?
微软和社区已经做了大量艰苦的工作,使.Net Core成为市场上具有竞争力的框架,帮助开发人员快速开发具有最佳性能和可扩展性的强大应用程序.做的最棒的事情是.Net Framework开发人员不需要任 ...
- Kafka producer拦截器(interceptor)
Kafka producer拦截器(interceptor) 拦截器原理 Producer拦截器(interceptor)是在Kafka 0.10版本被引入的,主要用于实现clients端的定制化控制 ...
- C#2.0新增功能02 泛型
连载目录 [已更新最新开发文章,点击查看详细] C# 语言和公共语言运行时 (CLR) 的 2.0 版本中添加了泛型. 泛型将类型参数的概念引入 .NET Framework,这样就可以设计具有 ...
- CSS画出三角形(利用Border)
画出三角形的原理是调整border(边框)的四个方向的宽度,线条样式以及颜色. 如果你将宽度调的足够大,改变不同方向的颜色,你就可以发现盒模型的border是四个梯形一样的线条. div{ width ...
- .Net微信网页开发之使用微信JS-SDK调用微信扫一扫功能
前言: 之前有个项目需要调用微信扫描二维码的功能,通过调用微信扫码二维码功能,然后去获取到系统中生成的二维码信息.正好微信JS-SDK提供了调用微信扫一扫的功能接口,下面让我们来看看是如何实现的吧. ...
- C#汽车租赁系统 完整版
Truck.cs类 //卡车类 public class Truck : Vehicle1 { //重载 public int Load { get; set; } //构造函数 public T ...
- 【JS档案揭秘】第一集 内存泄漏与垃圾回收
程序的运行需要内存,对于一些需要持续运行很久的程序,尤其是服务器进程,如果不及时释放掉不再需要的内存,就会导致内存堆中的占用持续走高,最终可能导致程序崩溃. 不再需要使用的内存,却一直占用着空间,得不 ...
- C++判断图像中一点是否在矩形中
需要判断出四条之间组成的矩形的范围,其中矩形的边缘可能是倾斜不平行于x或者y轴. 考虑和很久,参考博客http://blog.csdn.net/dapengbusi/article/details/5 ...
- 工作笔记--对接三方Http接口遇到的问题
在使用 HttpClient 4.4 调用第三方 http api 时遇到了很多问题,还好最后都解决了,记录一下遇到的问题及解决办法,希望对同样有此问题的你有所帮助. 环境说明 首先说明一点是,对方的 ...
- git基础学习
1.git是什么 内容寻址文件系统,分布式版本控制系统 2.git作用 开发过程中的版本控制 3.git基础命令 克隆git仓库---clone:git clone 仓库url 选分支---check ...