MyBatis編寫一個簡單的SQL生成工具
MyBatis 語法概覽
MyBatis 是一個強(qiáng)大的數(shù)據(jù)持久化框架,它提供了一種半自動化的 ORM 實現(xiàn)方式。通過 MyBatis,開發(fā)者可以通過簡單的 XML 或注解來配置和映射原生信息,將接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 對象)映射成數(shù)據(jù)庫中的記錄。
基本查詢語句
在 MyBatis 中,基本的查詢語句使用 <select> 標(biāo)簽定義。例如,以下是一個簡單的查詢語句:
<select id="selectPerson" parameterType="int" resultType="hashmap"> SELECT * FROM PERSON WHERE ID = #{id} ???????</select>
這個語句被稱為 selectPerson,接受一個 int 類型的參數(shù),并返回一個 HashMap 類型的對象。
參數(shù)和結(jié)果映射
MyBatis 允許使用 #{} 和 ${} 兩種方式獲取參數(shù)值。其中 #{} 是預(yù)處理語句參數(shù)(如 JDBC 的 ?),而 ${} 是直接進(jìn)行字符串替換。使用 #{} 可以有效防止 SQL 注入。
動態(tài) SQL
MyBatis 支持動態(tài) SQL,這意味著 SQL 語句可以根據(jù)傳入的參數(shù)動態(tài)變化。例如,使用 <if> 標(biāo)簽可以根據(jù)條件包含不同的 SQL 片段:
<select id="findActiveBlogLike" resultType="Blog"> SELECT * FROM BLOG WHERE state = ‘ACTIVE' <if test="title != null">AND title like #{title} </if> ???????</select>
在這個例子中,如果 title 參數(shù)不為 null,則會包含一個按標(biāo)題進(jìn)行模糊查詢的條件。
高級結(jié)果映射
MyBatis 的 <resultMap> 元素提供了高級結(jié)果映射功能。它允許開發(fā)者定義如何從數(shù)據(jù)庫結(jié)果集中加載對象,這是 MyBatis 最強(qiáng)大的特性之一。
緩存
MyBatis 提供了強(qiáng)大的緩存功能,可以通過簡單地在映射文件中添加 <cache> 標(biāo)簽來啟用二級緩存。
總結(jié)
MyBatis 通過簡化 SQL 操作和提供動態(tài) SQL 功能,使得數(shù)據(jù)庫操作變得更加靈活和強(qiáng)大。它的高級映射功能和緩存機(jī)制也為開發(fā)者提供了更多的便利。
實現(xiàn)代碼
import com.alibaba.fastjson2.util.DateUtils; import org.apache.commons.lang3.ObjectUtils; import java.util.Date; public interface BaseService { default Query query() { return new Query(); } default Update update() { return new Update(); } default Insert insert() { return new Insert(); } static String value(Object value) { if (ObjectUtils.isEmpty(value)) { return " NULL "; } if (value instanceof Date) { return "'" + DateUtils.format((Date) value, "yyyy-MM-dd HH:mm:ss") + "'"; } if (value instanceof String) { return "'" + value + "'"; } if (value instanceof Number) { return value.toString(); } throw new RuntimeException("無法解析的字段 :" + value); } class Insert { StringBuilder sqlBuilder = new StringBuilder(); StringBuilder inertFieldBuilder = new StringBuilder(); StringBuilder inertValueBuilder = new StringBuilder(); public Insert set(String column, Object value) { if (inertFieldBuilder.length() > 0) inertFieldBuilder.append(" , "); inertFieldBuilder.append(column); if (inertValueBuilder.length() > 0) inertValueBuilder.append(" , "); inertValueBuilder.append(" "); inertValueBuilder.append(value(value)); inertValueBuilder.append(" "); return this; } public String toString() { if (inertFieldBuilder.length() > 0 && inertValueBuilder.length() > 0) { sqlBuilder.append(" ( "); sqlBuilder.append(inertFieldBuilder.toString()); sqlBuilder.append(" ) "); sqlBuilder.append(" VALUES( "); sqlBuilder.append(inertValueBuilder.toString()); sqlBuilder.append(" ) "); } return sqlBuilder.toString(); } } class Update { StringBuilder sqlBuilder = new StringBuilder(); StringBuilder updateBuilder = new StringBuilder(); public Update set(String column, Object value) { if (updateBuilder.length() > 0) updateBuilder.append(" , "); updateBuilder.append(" "); updateBuilder.append(column); updateBuilder.append(" = "); updateBuilder.append(value(value)); updateBuilder.append(" "); return this; } public String toString() { if (updateBuilder.length() > 0) { sqlBuilder.append(updateBuilder.toString()); } return sqlBuilder.toString(); } } class Query { StringBuilder whereBuilder = new StringBuilder(); StringBuilder sqlBuilder = new StringBuilder(); public Query eq(String column, Object value) { if (ObjectUtils.isEmpty(value)) return this; if (whereBuilder.length() > 0) whereBuilder.append(" AND "); whereBuilder.append(" "); whereBuilder.append(column); whereBuilder.append(" = "); whereBuilder.append(value(value)); whereBuilder.append(" "); return this; } public Query or(String column, Object value) { if (ObjectUtils.isEmpty(value)) return this; if (whereBuilder.length() > 0) whereBuilder.append(" OR "); whereBuilder.append(" "); whereBuilder.append(column); whereBuilder.append(" = "); whereBuilder.append(value(value)); whereBuilder.append(" "); return this; } public Query like(String column, String value) { if (ObjectUtils.isEmpty(value)) return this; if (whereBuilder.length() > 0) whereBuilder.append(" AND "); whereBuilder.append(" "); whereBuilder.append(column); whereBuilder.append(" LIKE '%"); whereBuilder.append(value); whereBuilder.append("%' "); return this; } public Query in(String column, Object... values) { if (ObjectUtils.isEmpty(values)) return this; if (whereBuilder.length() > 0) whereBuilder.append(" AND "); whereBuilder.append(" "); whereBuilder.append(column); whereBuilder.append(" IN( "); int i; i = 0; for (Object value : values) { if (i > 0) whereBuilder.append(" , "); i++; whereBuilder.append(value(value)); } whereBuilder.append(" )"); return this; } public Query noIn(String column, Object... values) { if (ObjectUtils.isEmpty(values)) return this; if (whereBuilder.length() > 0) whereBuilder.append(" AND "); whereBuilder.append(" "); whereBuilder.append(column); whereBuilder.append(" NOT IN( "); int i; i = 0; for (Object value : values) { if (i > 0) whereBuilder.append(" , "); i++; whereBuilder.append(value(value)); } whereBuilder.append(" )"); return this; } public Query isNull(String column) { if (whereBuilder.length() > 0) whereBuilder.append(" AND "); whereBuilder.append(" ( LENGTH( "); whereBuilder.append(column); whereBuilder.append(" ) <=0 OR IS NULL ) "); return this; } public Query notNull(String column) { if (whereBuilder.length() > 0) whereBuilder.append(" AND "); whereBuilder.append(" ( LENGTH( "); whereBuilder.append(column); whereBuilder.append(" ) >0 OR IS NOT NULL ) "); return this; } public Query sql(Object sql) { if (ObjectUtils.isEmpty(sql)) return this; whereBuilder.append(sql.toString()); return this; } public Query and(String whereSql) { if (ObjectUtils.isEmpty(whereSql)) return this; if (whereBuilder.length() > 0) whereBuilder.append(" AND "); whereBuilder.append("( "); whereBuilder.append(whereSql); whereBuilder.append(" )"); return this; } public Query or(String whereSql) { if (ObjectUtils.isEmpty(whereSql)) return this; if (whereBuilder.length() > 0) whereBuilder.append(" OR "); whereBuilder.append("( "); whereBuilder.append(whereSql); whereBuilder.append(" )"); return this; } public String toString() { if (whereBuilder.length() > 0) { sqlBuilder.append(whereBuilder.toString()); } return sqlBuilder.toString(); } } }
作為參數(shù)通過mapper傳入XML作為【條件|行為】使用
// name = "張三" query().eq("name","張三").toString(); // name = "張三" update().set("name","張三").toString(); // (name) values("張三") insert().set("name","張三").toString();
到此這篇關(guān)于MyBatis編寫一個簡單的SQL生成工具的文章就介紹到這了,更多相關(guān)MyBatis SQL生成內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot如何動態(tài)改變?nèi)罩炯墑e
這篇文章主要介紹了SpringBoot如何動態(tài)改變?nèi)罩炯墑e,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下2020-12-12springboot根據(jù)實體類生成表的實現(xiàn)方法
本文介紹了如何通過SpringBoot工程引入SpringDataJPA,并通過實體類自動生成數(shù)據(jù)庫表的過程,包括常見問題解決方法,感興趣的可以了解一下2024-09-09Spring Boot LocalDateTime格式化處理的示例詳解
這篇文章主要介紹了Spring Boot LocalDateTime格式化處理的示例詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10struts2數(shù)據(jù)處理_動力節(jié)點Java學(xué)院整理
Struts2框架框架使用OGNL語言和值棧技術(shù)實現(xiàn)數(shù)據(jù)的流轉(zhuǎn)處理。下面通過本文給大家分享struts2數(shù)據(jù)處理的相關(guān)知識,感興趣的朋友參考下吧2017-09-09Springboot升級至2.4.0中出現(xiàn)的跨域問題分析及修改方案
這篇文章主要介紹了Springboot升級至2.4.0中出現(xiàn)的跨域問題分析及修改方案,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12