首页 > TAG信息列表 > updateById
springPlus-更新测试
承接:mybatisPlus-主键生成策略 1 在测试类中添加更新的方法 src/test/java/com/lv/mybatis_plus/MybatisPlusApplicationTests.java //测试更新 @Test public void testUpdate(){ User user = new User(); user.setId(9527L); user.setName("醍醐镇"); // 注意:使用事务注解导致DS数据源切换失效解决方法
先来看一下我的数据源配置,通过不同端口模拟多数据源配置: 目前业务需求是对superdata库里的数据做修改的同时game分库也同步进行修改,虽然只有一次关联还是使用了事务保证原子性,加上注解 @Transactional(rollbackFor = Exception.class)参数加上"rollbackFor = Exception.c关于mybatis plus出现There is no getter for property named ‘null‘ in ‘xx‘
在使用mybatis plus的 updateById报错 There is no getter for property named ‘null’ in ‘xx’ 后来发现是忘记加注解@TableId 解决方案::把实体类中的主键字段(如果设计数据库时没有设计主键,一般把在ID上即可,毕竟是updateById)加上这个注解,解决问题。 底层原理是mybatismybatis的updateById()出现问题时候,最好在mapper自己写一个方法....
mybatis的updateById出现问题,修改后但是数据库的表没有真正修改 这个问题用人话来说是: (1)表里面有1、2、3、4,我现在要删掉数字4; 但是删掉时候前端显示是4变成空字符串“”; (2)去数据库的表看还是1、2、3、4; (3)所以是updateById出现问题 还是乖乖地去mapper写SQL语句MyBatisPlus中updateById与updateAllColumnById方法区别
实现 updateById方法在插入时,会根据实体类的每个属性进行非空判断,只有非空的属性所对应的字段才会出现在SQL语句中。 updateAllColumnById方法在插入时,不管属性是否为空,属性所对应的字段都会出现在SQL语句中。MyBatis-Plus updateById方法无法更新字段为空字符串或null
需求 : 举例 : 当前员工表有入职和离职日期,离职后更新当前时间,再入职时更新入职时间并清空离职日期 解决方法 : 方法一 : 修改配置文件 MyBatis-Plus对字段的验证策略默认是1 field-strategy字段更新插入策略属性说明: IGNORED(0): "忽略判断", 所有字段都更新和插入 N