内容简介:simpleCurd简介: 只需要2个类即可实现类似mybatisPlus的功能,定义普通实体类就拥有curd功能,无需写mapper。 oschina项目地址:https://www.oschina.net/p/scofier-simplecurdscofier-simplecurd v1.0.1新增功能...
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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 类似Github的webhook实现
- ASP实现类似hashMap功能的类
- PHP实现类似题库抽题效果
- java实现golang类似的chan
- splash 实现类似selenium的WebDriverWait
- C++ 中类似 Python 的 dict 的实现
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。