封装动态SQL的插件

最近根据公司的业务需要封装了一个简单的动态SQL的插件,要求是允许用户在页面添加SQL的where条件,然后开发者只需要给某个接口写查询对应的表,参数全部由插件进行拼接完成。下面是最终实现:
开发人员只需要在接口写上下面的查询SQL,然后用户可以在页面上添加需要关联的字段,由于没有写页面所里这里直接数据库里面配置

SELECT * FROM user;

添加表字段

insert into t_table_field (id, table_name, table_alis, table_filed, table_filed_type, create_time, update_time, deleted)
values  (1, 'user', 'u', 'create_time', 'datetime', '2023-07-18 13:55:02', '2023-07-18 13:55:02', 0);

添加增强字段

insert into t_data_controller (id, creator, func_tag, left_field_id, expression, right_field_value, sort_id, relation_expression, create_time, update_time, deleted, group_id)
values  (1, 123, 'user/query', 1, '>', '${query.startTime}', 0, 'or', '2023-07-18 14:23:16', '2023-07-19 11:01:00', 0, 1),
        (2, 123, 'user/query', 1, '<=', '${query.endTime}', 1, 'and', '2023-07-18 14:39:21', '2023-07-19 11:01:00', 0, 1);

测试代码

@Test
public void test_page() {
    CustomerQuery customerQuery = new CustomerQuery()
    .setFuncTag("customer/query")
    .setStartTime(time)
    .setEndTime(endTime);
    IPage<Customer> customerPage = this.customerDao.selectPageDynamic(Condition.getPage(customerQuery), customerQuery);
}

最终代码拼接出来的样子

SELECT * FROM customer WHERE (create_time > 'Wed Apr 13 10:16:11 CST 2022' AND create_time <= 'Thu Apr 14 11:02:46 CST 2022') ORDER BY create_time DESC LIMIT ?

目前插件封装的比较仓促时间也不够,所以封装的比较简单,现在可以实现子查询的参数映射、where条件的拼接,表达式分组的实现,具体有兴趣的可以看看源码。
在这里插入图片描述
代码仓库

https://gitee.com/haijun1998/spring-boot-component-starter.git

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值