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新增功能

  1. 实现类似hibernate的PrePersist的功能
  2. 新增动态查询demo
  3. 新增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();
    }
}

其它更新

  1. 新增动态查询的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);
}
  1. 新增selectByCtgcodeolumn demo
@GetMapping("/test4")
public Object test4(String[] ids) {
    return Dal.with(User.class).selectByColumn("name",ids);
}

项目仓库地址:

https://gitee.com/scofier/SimpleCurd

展开阅读全文

0 收藏

分享

相关推荐: 对标小米手环 5:一加首款智能手环1月11日正式发布

  不得不说,可穿戴设备是目前主流手机厂商都想涉足的领域。   今日,一加官方通过海外媒体宣布,旗下首款智能手环将于 1 月 11 日正式发布。   此前有爆料称一加智能手环将首先在印度市场发布,随后再登陆其他地区市场。   随着发布日期的临近,该设备的渲染图…

Tags: , , , , , ,