亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MyBatis編寫一個(gè)簡(jiǎn)單的SQL生成工具

 更新時(shí)間:2025年03月11日 08:20:02   作者:instr  
MyBatis 是一個(gè)強(qiáng)大的數(shù)據(jù)持久化框架,它提供了一種半自動(dòng)化的 ORM 實(shí)現(xiàn)方式,本文將為大家介紹如何使用MyBatis編寫一個(gè)簡(jiǎn)單的SQL生成工具,需要的可以了解下

MyBatis 語(yǔ)法概覽

MyBatis 是一個(gè)強(qiáng)大的數(shù)據(jù)持久化框架,它提供了一種半自動(dòng)化的 ORM 實(shí)現(xiàn)方式。通過(guò) MyBatis,開(kāi)發(fā)者可以通過(guò)簡(jiǎn)單的 XML 或注解來(lái)配置和映射原生信息,將接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 對(duì)象)映射成數(shù)據(jù)庫(kù)中的記錄。

基本查詢語(yǔ)句

在 MyBatis 中,基本的查詢語(yǔ)句使用 <select> 標(biāo)簽定義。例如,以下是一個(gè)簡(jiǎn)單的查詢語(yǔ)句:

<select id="selectPerson" parameterType="int" resultType="hashmap">
SELECT * FROM PERSON WHERE ID = #{id}
???????</select>

這個(gè)語(yǔ)句被稱為 selectPerson,接受一個(gè) int 類型的參數(shù),并返回一個(gè) HashMap 類型的對(duì)象。

參數(shù)和結(jié)果映射

MyBatis 允許使用 #{} 和 ${} 兩種方式獲取參數(shù)值。其中 #{} 是預(yù)處理語(yǔ)句參數(shù)(如 JDBC 的 ?),而 ${} 是直接進(jìn)行字符串替換。使用 #{} 可以有效防止 SQL 注入。

動(dòng)態(tài) SQL

MyBatis 支持動(dòng)態(tài) SQL,這意味著 SQL 語(yǔ)句可以根據(jù)傳入的參數(shù)動(dòng)態(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>

在這個(gè)例子中,如果 title 參數(shù)不為 null,則會(huì)包含一個(gè)按標(biāo)題進(jìn)行模糊查詢的條件。

高級(jí)結(jié)果映射

MyBatis 的 <resultMap> 元素提供了高級(jí)結(jié)果映射功能。它允許開(kāi)發(fā)者定義如何從數(shù)據(jù)庫(kù)結(jié)果集中加載對(duì)象,這是 MyBatis 最強(qiáng)大的特性之一。

緩存

MyBatis 提供了強(qiáng)大的緩存功能,可以通過(guò)簡(jiǎn)單地在映射文件中添加 <cache> 標(biāo)簽來(lái)啟用二級(jí)緩存。

總結(jié)

MyBatis 通過(guò)簡(jiǎn)化 SQL 操作和提供動(dòng)態(tài) SQL 功能,使得數(shù)據(jù)庫(kù)操作變得更加靈活和強(qiáng)大。它的高級(jí)映射功能和緩存機(jī)制也為開(kāi)發(fā)者提供了更多的便利。

實(shí)現(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("無(wú)法解析的字段 :" + 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ù)通過(guò)mapper傳入XML作為【條件|行為】使用

//  name = "張三"
query().eq("name","張三").toString();
//  name = "張三"
update().set("name","張三").toString();
//  (name) values("張三")
insert().set("name","張三").toString();

到此這篇關(guān)于MyBatis編寫一個(gè)簡(jiǎn)單的SQL生成工具的文章就介紹到這了,更多相關(guān)MyBatis SQL生成內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Java中Thread 和Runnable區(qū)別

    詳解Java中Thread 和Runnable區(qū)別

    這篇文章主要介紹了Java中Thread 和Runnable的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • spring框架集成flyway項(xiàng)目的詳細(xì)過(guò)程

    spring框架集成flyway項(xiàng)目的詳細(xì)過(guò)程

    今天通過(guò)本文給大家分享spring框架集成flyway項(xiàng)目的詳細(xì)過(guò)程,由于大多數(shù)都是springboot集成flyway,很少見(jiàn)到spring框架的項(xiàng)目,今天就抽空給大家介紹下spring框架集成flyway項(xiàng)目的方法,一起看看吧
    2021-07-07
  • SpringBoot如何動(dòng)態(tài)改變?nèi)罩炯?jí)別

    SpringBoot如何動(dòng)態(tài)改變?nèi)罩炯?jí)別

    這篇文章主要介紹了SpringBoot如何動(dòng)態(tài)改變?nèi)罩炯?jí)別,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下
    2020-12-12
  • springboot根據(jù)實(shí)體類生成表的實(shí)現(xiàn)方法

    springboot根據(jù)實(shí)體類生成表的實(shí)現(xiàn)方法

    本文介紹了如何通過(guò)SpringBoot工程引入SpringDataJPA,并通過(guò)實(shí)體類自動(dòng)生成數(shù)據(jù)庫(kù)表的過(guò)程,包括常見(jiàn)問(wèn)題解決方法,感興趣的可以了解一下
    2024-09-09
  • Spring Boot LocalDateTime格式化處理的示例詳解

    Spring Boot LocalDateTime格式化處理的示例詳解

    這篇文章主要介紹了Spring Boot LocalDateTime格式化處理的示例詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • Java模板動(dòng)態(tài)生成word文件的方法步驟

    Java模板動(dòng)態(tài)生成word文件的方法步驟

    最近項(xiàng)目中需要根據(jù)模板生成word文檔,模板文件也是word文檔。本文使用使用freemarker模板生成word文件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 淺談Java線程池的7大核心參數(shù)

    淺談Java線程池的7大核心參數(shù)

    本篇文章基于正在看這篇文章的你已經(jīng)具備了基本的Java并發(fā)的相關(guān)知識(shí).如果對(duì)于Java并發(fā)編程一無(wú)所知的話,請(qǐng)先看看Java并發(fā)編程的一些前導(dǎo)基礎(chǔ)知識(shí),文中有非常詳細(xì)的圖文示例及代碼,,需要的朋友可以參考下
    2021-05-05
  • struts2數(shù)據(jù)處理_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    struts2數(shù)據(jù)處理_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    Struts2框架框架使用OGNL語(yǔ)言和值棧技術(shù)實(shí)現(xiàn)數(shù)據(jù)的流轉(zhuǎn)處理。下面通過(guò)本文給大家分享struts2數(shù)據(jù)處理的相關(guān)知識(shí),感興趣的朋友參考下吧
    2017-09-09
  • Java中joda日期格式化工具的使用示例

    Java中joda日期格式化工具的使用示例

    這篇文章主要介紹了Java中joda日期格式化工具的使用示例,幫助大家更好的利用Java處理時(shí)間,感興趣的朋友可以了解下
    2021-01-01
  • Springboot升級(jí)至2.4.0中出現(xiàn)的跨域問(wèn)題分析及修改方案

    Springboot升級(jí)至2.4.0中出現(xiàn)的跨域問(wèn)題分析及修改方案

    這篇文章主要介紹了Springboot升級(jí)至2.4.0中出現(xiàn)的跨域問(wèn)題分析及修改方案,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12

最新評(píng)論