simpleCurd简介:
只需要2个类即可实现类似mybatisPlus的功能,定义普通实体类就拥有curd功能,无需写mapper。
oschina项目地址:https://www.oschina.net/p/scofier-simplecurdscofier-simplecurd
v1.0.1新增功能:
- 实现类似hibernate的
PrePersist的功能
- 新增动态查询demo
- 新增
selectByColumn的demo
实现类似hibernate的PrePersist的功能,具体示例如下:
定义Entity,比如User
@Table(name = "user")
public class User implements BaseMapper.Interceptor {
String id;
String name;
String phone;
@Override
public void prePersist() {
if(null==id){
id= UUID.randomUUID().toString();
}
}
}
实现:BaseMapper.Interceptor 接口就可以了
代码实现原理
String buildSql(Object criteria , TableInfo table) {
this.table = table;
SQL sql = sql(criteria, null);
beforeInterceptor(criteria, sql);//执行前置逻辑
return String.format("<script>%s</script>", sql.toString());
}
void beforeInterceptor(Object obj, SQL sql) {
if(obj instanceof Interceptor && this instanceof WriteType) {
((Interceptor)obj).prePersist();
}
}
其它更新
- 新增动态查询的demo
@GetMapping("/test3")
public Object test3(User user) {
return Dal.with(User.class).query(sql -> {
sql.WHERE(user.getPhone() != null, "phone=#{phone}");
return sql.SELECT("id,name").WHERE("name=#{name}");
}, user);
}
- 新增
selectByColumn demo
@GetMapping("/test4")
public Object test4(String[] ids) {
return Dal.with(User.class).selectByColumn("name",ids);
}
项目仓库地址:
https://gitee.com/scofier/SimpleCurd