이 글은 SpringBoot Mybatis Plus의 공개 필드 자동 채우기 기능에 대한 관련 정보를 주로 소개합니다. 필요한 친구가 참고할 수 있습니다
1.
일반적으로 객체 테이블을 작성할 때 마지막 수정 시간과 마지막 수정 사람이라는 두 가지 필드가 있습니다. 대부분의 테이블에 있는 이러한 필드의 경우 추가하거나 수정할 때마다 이를 고려해야 합니다. 여러 필드가 전달되었는지 아는 것은 매우 번거로운 작업입니다. mybatisPlus에는 훌륭한 솔루션이 있습니다. 공개 필드를 자동으로 채워주는 기능입니다. 일반적으로 이 함수는 다음 조건을 충족하는 필드에 사용할 수 있습니다. 이 필드는 대부분의 테이블에서 찾을 수 있습니다. 이 필드의 값은 고정되어 있거나 백그라운드에서 필드 값을 동적으로 얻을 수 있습니다. 일반적으로 사용되는 두 가지 필드는 last_update_time과 last_update_name입니다.2. MybatisPlus 구성
가이드 패키지: 유일하게 주의할 점은 mybatisPlus가 버전 2.0.6에서만 지원된다는 것입니다업데이트데이터 공개 필드는 자동으로 채워집니다. 이전에는 새 데이터를 추가할 때만 사용할 수 있었습니다.
이전에 MybatisPlus를 구성한 경우 다음 단계만 추가하면 됩니다:IMetaObjectHandler추상 클래스 상속 및 insertFill() new 구현 두 가지 메소드가 있습니다: 데이터를 추가할 때 채워야 하는 필드 설정과 updateFill()이 데이터를 업데이트할 때 채워야 하는 필드 설정:
package io.z77z.util; import java.util.Date; import org.apache.ibatis.reflection.MetaObject; import org.apache.shiro.SecurityUtils; import org.springframework.stereotype.Component; import com.baomidou.mybatisplus.mapper.MetaObjectHandler; import io.z77z.entity.SysUser; /** mybatisplus自定义填充公共字段 ,即没有传的字段自动填充*/ @Component public class MyMetaObjectHandler extends MetaObjectHandler { //新增填充 @Override public void insertFill(MetaObject metaObject) { Object lastUpdateNameId = metaObject.getValue("lastUpdateNameId"); Object lastUpdateTime = metaObject.getValue("lastUpdateTime"); //获取当前登录用户 SysUser user = (SysUser)SecurityUtils.getSubject().getPrincipal(); if (null == lastUpdateNameId) { metaObject.setValue("lastUpdateNameId", user.getId()); } if (null == lastUpdateTime) { metaObject.setValue("lastUpdateTime", new Date()); } } //更新填充 @Override public void updateFill(MetaObject metaObject) { insertFill(metaObject); } }참고: getValue() 메소드의 매개변수는
pojo 클래스 의 변수(Camel Case 명명).
mybatisplus의 구성 파일 에서 public 필드 생성 클래스의 bean:
// MP 全局配置,更多内容进入类看注释 GlobalConfiguration globalConfig = new GlobalConfiguration(); //配置公共字段自动填写 globalConfig.setMetaObjectHandler(new MyMetaObjectHandler());는 public 필드를 채우는 설정입니다. 방금 MP 전역 구성 개체에 기록되었습니다. 채워진 필드는 유효성 검사를 무시해야 합니다. 테이블 개체 pojo 클래스의 해당
/** * 最后修改人Id */ @TableField(value="last_update_id",validate=FieldStrategy.NOT_EMPTY) private String lastUpdateNameId; /** * 最后修改时间 */ @TableField(value="last_update_time",validate=FieldStrategy.NOT_EMPTY) private Date lastUpdateTime;이유: 업데이트 및 삽입 메서드가 호출되면 이 속성을 업데이트하고 삽입해야 하는지 결정하기 위해 전달한 속성이 비어 있는지 확인합니다. 이는 공개 필드의 자동 채우기와 충돌하므로 이 속성에 확인이 필요하지 않음을 식별하는 데 이 주석이 필요합니다. 그렇지 않으면 삽입 중에 채우기가 실패합니다.
3. 테스트 수업 작성아아앙
4. 테스트 로그
2017/04/23-19:35:26 [main] DEBUG io.z77z.dao.SysUserMapper.insert- ==> 준비 중: INSERT INTO sys_user(id, 닉네임, 이메일, pswd,`status`,last_update_name_id , last_update_time ) VALUES ( ?, ?, ?, ?, ?,?, ? )2017/04/23-19:35:26 [main] DEBUG io.z77z.dao.SysUserMapper.insert- ==> ; 매개변수: 6634923de4a14b6ca3bac5fdf31563a8(문자열), z77z(문자열), 1093615728@qq.com(문자열), 123123(문자열), 1(문자열), 123(문자열), 2017-04-23 19:35:26.58(타임 스탬프 )
2017/04/23-19:35:26 [main] DEBUG io.z77z.dao.SysUserMapper.insert- 0cb8a9adeacf8cfa7647e4730e9ca238 매개변수: 6634923de4a14b6ca3bac5fdf31563a8(String)
201 7/ 04/23-19:35:26 [main] DEBUG io.z77z.dao.SysUserMapper.selectById- 94034e22b56c4800744dc3b0aa4872f8 준비 중: sys_user SET pswd=?, last_update_name_id=?, last_update_time=?
2017/04/23-19:35:26 [main] DEBUG io.z77z.dao.SysUserMapper.updateById- ==> 매개변수: 123(String), 123(String), 2017-04-23 19 :35:26.637(타임스탬프), 6634923de4a14b6ca3bac5fdf31563a8(문자열)
2 017/04 /23-19:35:26 [main] DEBUG io.z77z.dao.SysUserMapper.updateById- 577b2699d7be4081276f9b1ed2f5d40b 준비 중: SELECT id,nickname,email,pswd,last_login_time AS lastLoginTime,`status`,last_update_name_id AS lastUpdateNameId,create_name_id AS createNameId,last_update_time AS lastUpdateTime,create_time AS createTime FROM sys_user WHERE id= ?
2017/04/23-19:35:26 [main] DEBUG io.z77z.dao.SysUserMapper.selectById- == > 매개변수: 6634923de4a14b6ca3bac5fdf31563a8(String)
2017/04/23-19: 35:26 [main] DEBUG io.z77z.dao.SysUserMapper.selectById- <== 총계: 1
5. 요약
원래는 이 방법을 사용하여 생성자와 생성 시간을 처리할 계획이었습니다. 최종적으로 이 두 필드도 비어 있는 것으로 무시되는 경우, 즉 데이터 업데이트 시에 verify=FieldStrategy.NOT_EMPTY를 추가하는 것으로 나타났습니다. 작성자와 생성 시간이 함께 업데이트됩니다. 그렇지 않으면 비어 있는 상태로 업데이트됩니다. 그래서 mybatisPlus의 public field autofill 기능은 좋다고 생각하지만, 실제 필요에 따라 사용하면 완벽하지는 않습니다.
[관련 추천]
위 내용은 Mybatis Plus의 공개 필드 자동 채우기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!