simpleCurd v1.0.1 更新,实现类似 hibernate 的 PrePersist 功能
2021年1月10日 | by tgcode
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("%s", 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); }
- 新增
selectByCtgcodeolumn
demo
@GetMapping("/test4") public Object test4(String[] ids) { return Dal.with(User.class).selectByColumn("name",ids); }
项目仓库地址:
本站新闻禁止未经授权转载,违者依法追究相关法律责任。授权请联系:oscbianji#oschina.cn
本文tgcode标题:simpleCurd v1.0.1 更新,实现类似 hibernate 的 PrePersist 功能
0 收藏
分享
热门文章
相关推荐: 对标小米手环 5:一加首款智能手环1月11日正式发布
不得不说,可穿戴设备是目前主流手机厂商都想涉足的领域。 今日,一加官方通过海外媒体宣布,旗下首款智能手环将于 1 月 11 日正式发布。 此前有爆料称一加智能手环将首先在印度市场发布,随后再登陆其他地区市场。 随着发布日期的临近,该设备的渲染图…