IT评测·应用市场-qidao123.com

标题: 写一个简单的SQL天生工具 [打印本页]

作者: 吴旭华    时间: 2025-3-10 16:19
标题: 写一个简单的SQL天生工具
知识点:

MyBatis 语法概览

MyBatis 是一个强大的数据持久化框架,它提供了一种半主动化的 ORM 实现方式。通过 MyBatis,开发者可以通过简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记载。
基本查询语句

在 MyBatis 中,基本的查询语句使用  标签界说。例如,以下是一个简单的查询语句:
SELECT * FROM PERSON WHERE ID = #{id}这个语句被称为 selectPerson,担当一个 int 类型的参数,并返回一个 HashMap 类型的对象。
参数和结果映射

MyBatis 允许使用 #{} 和 ${} 两种方式获取参数值。此中 #{} 是预处理语句参数(如 JDBC 的 ?),而 ${} 是直接进行字符串替换。使用 #{} 可以有效防止 SQL 注入。
动态 SQL

MyBatis 支持动态 SQL,这意味着 SQL 语句可以根据传入的参数动态变化。例如,使用  标签可以根据条件包含不同的 SQL 片段:
SELECT * FROM BLOG WHERE state = ‘ACTIVE’AND title like #{title}在这个例子中,如果 title 参数不为 null,则会包含一个按标题进行模糊查询的条件。
高级结果映射

MyBatis 的  元素提供了高级结果映射功能。它允许开发者界说如何从数据库结果会合加载对象,这是 MyBatis 最强大的特性之一。
缓存

MyBatis 提供了强大的缓存功能,可以通过简单地在映射文件中添加  标签来启用二级缓存。
总结

MyBatis 通过简化 SQL 操作和提供动态 SQL 功能,使得数据库操作变得更加灵活和强大。它的高级映射功能和缓存机制也为开发者提供了更多的便利。
代码:
  1. import com.alibaba.fastjson2.util.DateUtils;
  2. import org.apache.commons.lang3.ObjectUtils;
  3. import java.util.Date;
  4. public interface BaseService {
  5.     default Query query() {
  6.         return new Query();
  7.     }
  8.     default Update update() {
  9.         return new Update();
  10.     }
  11.     default Insert insert() {
  12.         return new Insert();
  13.     }
  14.     static String value(Object value) {
  15.         if (ObjectUtils.isEmpty(value)) {
  16.             return " NULL ";
  17.         }
  18.         if (value instanceof Date) {
  19.             return "'" + DateUtils.format((Date) value, "yyyy-MM-dd HH:mm:ss") + "'";
  20.         }
  21.         if (value instanceof String) {
  22.             return "'" + value + "'";
  23.         }
  24.         if (value instanceof Number) {
  25.             return value.toString();
  26.         }
  27.         throw new RuntimeException("无法解析的字段 :" + value);
  28.     }
  29.     class Insert {
  30.         StringBuilder sqlBuilder = new StringBuilder();
  31.         StringBuilder inertFieldBuilder = new StringBuilder();
  32.         StringBuilder inertValueBuilder = new StringBuilder();
  33.         public Insert set(String column, Object value) {
  34.             if (inertFieldBuilder.length() > 0) inertFieldBuilder.append(" , ");
  35.             inertFieldBuilder.append(column);
  36.             if (inertValueBuilder.length() > 0) inertValueBuilder.append(" , ");
  37.             inertValueBuilder.append(" ");
  38.             inertValueBuilder.append(value(value));
  39.             inertValueBuilder.append(" ");
  40.             return this;
  41.         }
  42.         public String toString() {
  43.             if (inertFieldBuilder.length() > 0 && inertValueBuilder.length() > 0) {
  44.                 sqlBuilder.append(" ( ");
  45.                 sqlBuilder.append(inertFieldBuilder.toString());
  46.                 sqlBuilder.append(" ) ");
  47.                 sqlBuilder.append(" VALUES( ");
  48.                 sqlBuilder.append(inertValueBuilder.toString());
  49.                 sqlBuilder.append(" ) ");
  50.             }
  51.             return sqlBuilder.toString();
  52.         }
  53.     }
  54.     class Update {
  55.         StringBuilder sqlBuilder = new StringBuilder();
  56.         StringBuilder updateBuilder = new StringBuilder();
  57.         public Update set(String column, Object value) {
  58.             if (updateBuilder.length() > 0) updateBuilder.append(" , ");
  59.             updateBuilder.append(" ");
  60.             updateBuilder.append(column);
  61.             updateBuilder.append(" = ");
  62.             updateBuilder.append(value(value));
  63.             updateBuilder.append(" ");
  64.             return this;
  65.         }
  66.         public String toString() {
  67.             if (updateBuilder.length() > 0) {
  68.                 sqlBuilder.append(updateBuilder.toString());
  69.             }
  70.             return sqlBuilder.toString();
  71.         }
  72.     }
  73.     class Query {
  74.         StringBuilder whereBuilder = new StringBuilder();
  75.         StringBuilder sqlBuilder = new StringBuilder();
  76.         public Query eq(String column, Object value) {
  77.             if (ObjectUtils.isEmpty(value)) return this;
  78.             if (whereBuilder.length() > 0) whereBuilder.append(" AND ");
  79.             whereBuilder.append(" ");
  80.             whereBuilder.append(column);
  81.             whereBuilder.append(" = ");
  82.             whereBuilder.append(value(value));
  83.             whereBuilder.append(" ");
  84.             return this;
  85.         }
  86.         public Query or(String column, Object value) {
  87.             if (ObjectUtils.isEmpty(value)) return this;
  88.             if (whereBuilder.length() > 0) whereBuilder.append(" OR ");
  89.             whereBuilder.append(" ");
  90.             whereBuilder.append(column);
  91.             whereBuilder.append(" = ");
  92.             whereBuilder.append(value(value));
  93.             whereBuilder.append(" ");
  94.             return this;
  95.         }
  96.         public Query like(String column, String value) {
  97.             if (ObjectUtils.isEmpty(value)) return this;
  98.             if (whereBuilder.length() > 0) whereBuilder.append(" AND ");
  99.             whereBuilder.append(" ");
  100.             whereBuilder.append(column);
  101.             whereBuilder.append(" LIKE '%");
  102.             whereBuilder.append(value);
  103.             whereBuilder.append("%' ");
  104.             return this;
  105.         }
  106.         public Query in(String column, Object... values) {
  107.             if (ObjectUtils.isEmpty(values)) return this;
  108.             if (whereBuilder.length() > 0) whereBuilder.append(" AND ");
  109.             whereBuilder.append(" ");
  110.             whereBuilder.append(column);
  111.             whereBuilder.append(" IN( ");
  112.             int i;
  113.             i = 0;
  114.             for (Object value : values) {
  115.                 if (i > 0) whereBuilder.append(" , ");
  116.                 i++;
  117.                 whereBuilder.append(value(value));
  118.             }
  119.             whereBuilder.append(" )");
  120.             return this;
  121.         }
  122.         public Query noIn(String column, Object... values) {
  123.             if (ObjectUtils.isEmpty(values)) return this;
  124.             if (whereBuilder.length() > 0) whereBuilder.append(" AND ");
  125.             whereBuilder.append(" ");
  126.             whereBuilder.append(column);
  127.             whereBuilder.append(" NOT IN( ");
  128.             int i;
  129.             i = 0;
  130.             for (Object value : values) {
  131.                 if (i > 0) whereBuilder.append(" , ");
  132.                 i++;
  133.                 whereBuilder.append(value(value));
  134.             }
  135.             whereBuilder.append(" )");
  136.             return this;
  137.         }
  138.         public Query isNull(String column) {
  139.             if (whereBuilder.length() > 0) whereBuilder.append(" AND ");
  140.             whereBuilder.append(" ( LENGTH( ");
  141.             whereBuilder.append(column);
  142.             whereBuilder.append(" ) <=0 OR IS NULL ) ");
  143.             return this;
  144.         }
  145.         public Query notNull(String column) {
  146.             if (whereBuilder.length() > 0) whereBuilder.append(" AND ");
  147.             whereBuilder.append(" ( LENGTH( ");
  148.             whereBuilder.append(column);
  149.             whereBuilder.append(" ) >0 OR IS NOT NULL ) ");
  150.             return this;
  151.         }
  152.         public Query sql(Object sql) {
  153.             if (ObjectUtils.isEmpty(sql)) return this;
  154.             whereBuilder.append(sql.toString());
  155.             return this;
  156.         }
  157.         public Query and(String whereSql) {
  158.             if (ObjectUtils.isEmpty(whereSql)) return this;
  159.             if (whereBuilder.length() > 0) whereBuilder.append(" AND ");
  160.             whereBuilder.append("( ");
  161.             whereBuilder.append(whereSql);
  162.             whereBuilder.append(" )");
  163.             return this;
  164.         }
  165.         public Query or(String whereSql) {
  166.             if (ObjectUtils.isEmpty(whereSql)) return this;
  167.             if (whereBuilder.length() > 0) whereBuilder.append(" OR ");
  168.             whereBuilder.append("( ");
  169.             whereBuilder.append(whereSql);
  170.             whereBuilder.append(" )");
  171.             return this;
  172.         }
  173.         public String toString() {
  174.             if (whereBuilder.length() > 0) {
  175.                 sqlBuilder.append(whereBuilder.toString());
  176.             }
  177.             return sqlBuilder.toString();
  178.         }
  179.     }
  180. }
复制代码
作为参数通过mapper传入XML作为【条件|行为】使用:
  1. //  name = "张三"
  2. query().eq("name","张三").toString();
  3. //  name = "张三"
  4. update().set("name","张三").toString();
  5. //  (name) values("张三")
  6. insert().set("name","张三").toString();
复制代码
 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/) Powered by Discuz! X3.4