内容简介: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 的实现
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
我的第一本编程书
[日]平山尚 / 张沈宇 / 人民邮电出版社 / 2016-7 / 79.00元
写这本书之前,作者一直在摸索一种最有利于入门者学编程的方法,并应用到教学当中。经过两年的教学实践,他确信他的方法是有效的,于是便有了这本书。这本书面向的是完全没有接触过编程的读者。作者将门槛设置得非常低,读者不需要懂得变量、函数这些名词(这些名词在书中也不会出现),不需要会英语,完全不需要查阅其他书籍,只需要小学算术水平即可。这本书给初学者非常平缓的学习曲线,有利于为之后的进阶学习打下坚实的基础。一起来看看 《我的第一本编程书》 这本书的介绍吧!