Easter79 Easter79
3年前
springboot2结合mybatis拦截器实现主键自动生成
前言前阵子和朋友聊天,他说他们项目有个需求,要实现主键自动生成,不想每次新增的时候,都手动设置主键。于是我就问他,那你们数据库表设置主键自动递增不就得了。他的回答是他们项目目前的id都是采用雪花算法来生成,因此为了项目稳定性,不会切换id的生成方式。朋友问我有没有什么实现思路,他们公司的orm框架是mybatis,我就建议他说,不然让你老大把m
kenx kenx
3年前
mybatis if else if 条件判断SQL片段表达式取值和拼接
前言最近在开发项目的时候涉及到复杂的动态条件查询,但是mybaits本身不支持ifelseif类似的判断但是我们可以间接通过chosewhenotherwise去实现其中choose为一个整体when是ifotherwise是else快速使用以前我们进行条件判断时候使用if标签进行判断,条件并列存在xml
Stella981 Stella981
3年前
Spring Transaction + MyBatis SqlSession事务管理机制研究学习
    原文地址:SpringTransactionMyBatisSqlSession事务管理机制研究学习(https://www.oschina.net/action/GoToLink?urlhttp%3A%2F%2Fwww.xx566.com%2Fdetail%2F191.html)  线上的系统中,使用的是SpringMyba
Stella981 Stella981
3年前
MyBatis初级实战之六:一对多关联查询
欢迎访问我的GitHubhttps://github.com/zq2599/blog\_demos(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fgithub.com%2Fzq2599%2Fblog_demos)内容:所有原创文章分类汇总及配套源码,涉及Java、Doc
Stella981 Stella981
3年前
SpringBoot+Redis+拦截器+自定义注解实现接口幂等性
一、概念任意多次执行所产生的影响均与一次执行的影响相同。按照这个含义,最终的含义就是对数据库的影响只能是一次性的,不能重复处理。比如:订单接口,不能多次创建订单。支付接口,重复支付同一笔订单只能扣一次钱。支付宝回调接口,可能会多次回调,必须处理重复回调。普通表单提交接口
Stella981 Stella981
3年前
Mybatis执行SQL的4大基础组件详解(图文并茂)
\温馨提示:本篇是源码分析MybatisShardingJdbcSQL语句执行的前置篇。1、Executorsql执行器,其对应的类全路径:org.apache.ibatis.executor.Executor。1.1Executor类图!在这里插入图片描述(https://imgblog.csdn
Stella981 Stella981
3年前
MyBatis创建实体对象时获取自动生成的主键值
例如表结构:CREATETABLEperson(idBIGINTNOTNULLAUTO_INCREMENTPRIMARYKEY,nameVARCHAR(30));实体类:publicclassPerson{privatelo
Easter79 Easter79
3年前
SpringBoot+Redis+拦截器+自定义注解实现接口幂等性
一、概念任意多次执行所产生的影响均与一次执行的影响相同。按照这个含义,最终的含义就是对数据库的影响只能是一次性的,不能重复处理。比如:订单接口,不能多次创建订单。支付接口,重复支付同一笔订单只能扣一次钱。支付宝回调接口,可能会多次回调,必须处理重复回调。普通表单提交接口
Stella981 Stella981
3年前
MyBatis版本升级引发的线上告警回顾及原理分析
!(https://oscimg.oschina.net/oscnet/upcdd3545731fbcea0fe15d95b6a2f3e038aa.png)背景某天晚上,美团到店事业群某项系统服务正在进行常规需求的上线。因为在内部的Plus系统发布时,提示infbom版本需要升级,于是我们就将infbom版本从1.3.9.6升级至1
Stella981 Stella981
3年前
Mybatis批量更新报错com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException
批量更新数据,非常简单的一段代码,硬是报错,插入的数据也能显示出来List<UseruserlistnewArrayList<User();userlist.add(newUser(1,"qq","123132","eee"));userlist.add(newUser(2,"3333","123132","rr