欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot?mybatis-plus使用json字段實戰(zhàn)指南

 更新時間:2024年01月31日 09:21:50   作者:張三瘋不瘋  
在現(xiàn)代應用開發(fā)中經(jīng)常會使用JSON格式存儲和傳輸數(shù)據(jù),為了便捷地處理數(shù)據(jù)庫中的JSON字段,MyBatis-Plus提供了強大的JSON處理器,這篇文章主要給大家介紹了關于SpringBoot?mybatis-plus使用json字段的相關資料,需要的朋友可以參考下

1.前言

在springboot項目開發(fā)中,一般使用關系型數(shù)據(jù)庫作為主庫存儲數(shù)據(jù),有時候業(yè)務場景需要在既有的表結構上,擴展自定義業(yè)務信息. 這種場景下一般使用json類型存儲。本文總結springboot項目中,借助mybatis-plus操作json實踐方案

2.方案分析

2.1 為什么是json

JSON類型相對于傳統(tǒng)的關系型結構,其具有數(shù)據(jù)本身對結構描述、動態(tài)擴展和嵌套等特性,能夠更加自由地表示和存儲數(shù)據(jù)

2.2 數(shù)據(jù)庫的選擇

json字段的存儲依賴于底層選擇的數(shù)據(jù)庫, 有的關系型數(shù)據(jù)庫已經(jīng)支持json,比如MySQL5.7版本中,引入了JSON類型。如果沒有特殊的json類型, 我們可以使用text類型存儲json文本。因此要分兩種情況分析. 這兩種模式區(qū)別:

  • 提供json類型數(shù)據(jù)庫,在查詢靈活程度上更高,比如可以針對json指定key的value進行查詢。text之惡能作為普通文本匹配
  • 提供json類型數(shù)據(jù)庫,查詢會部分依賴底層特殊查詢語法. text則是通用的數(shù)據(jù)類型不存在該情況。

3. 實戰(zhàn)

無論底層數(shù)據(jù)庫使用text類型還是json類型。持久層使用mybatis-plus都要處理json與對象的映射問題。創(chuàng)建一個Account賬號對象為例,增加一個extendJson作為存儲擴展數(shù)據(jù)的json對象

@TableName(value = "account", autoResultMap = true)
public class Account {

    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private String username;

    /**
     * 注意??! 必須開啟映射注解
     *
     * @TableName(autoResultMap = true)
     * <p>
     * 以下兩種類型處理器,二選一 也可以同時存在
     * <p>
     * 注意??!選擇對應的 JSON 處理器也必須存在對應 JSON 解析依賴包
     */
    //@TableField(typeHandler = JacksonTypeHandler.class)
    @TableField(typeHandler = FastjsonTypeHandler.class)
    private JSONObject extendJson;

    //setter/getter忽略

以上部分主要參考mp官網(wǎng):https://baomidou.com/ >>字段類型處理器

3.1 使用text字段(h2數(shù)據(jù)庫)

使用text字段測試json字段我們使用h2數(shù)據(jù)庫進行測試

  • h2版本: 1.4.200(該版本不支持原生的json字段)

3.1.1 建表語句

使用liquibase管理建表語句

<?xml version="1.1" encoding="UTF-8" standalone="no"?>
<databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog" xmlns:ext="http://www.liquibase.org/xml/ns/dbchangelog-ext" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog-ext http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-ext.xsd http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.5.xsd">

    <changeSet author="demo" id="account.createTable">
        <createTable tableName="account" remarks="賬號表">
            <!--設置id自增 起始位置從10000 每次加1-->
            <column name="id" remarks="賬戶ID" type="bigint" autoIncrement="true" incrementBy="1" startWith="10000">
                <constraints primaryKey="true" nullable="false"/>
            </column>
            <!--用戶名增加唯一索引-->
            <column name="username" remarks="用戶名" type="VARCHAR(32)">
                <constraints nullable="false" unique="true" uniqueConstraintName="uniq_username"/>
            </column>
            <column name="password" remarks="密碼" type="VARCHAR(32)"/>
            <column name="name" remarks="姓名" type="VARCHAR(20)"/>
            <column name="sex" remarks="性別" type="CHAR(1)"/>
            <column name="phone" remarks="手機" type="VARCHAR(100)"/>
            <column name="email" remarks="郵件" type="VARCHAR(100)"/>
            <column name="create_time" remarks="創(chuàng)建時間" type="datetime(0)"/>
            <column name="update_time" remarks="修改時間" type="datetime(0)"/>
<!--            <column name="extend_json" remarks="拓展字段使用" type="json"/>-->
            <column name="extend_json" remarks="拓展字段使用" type="text"/>
        </createTable>
    </changeSet>

    <!--loadData:加載 csv 文件到已存在的表中-->
    <changeSet author="easy-log-demo" id="account.loadData" >
        <loadData tableName="account" file="db/liquibase/csv/account.csv" >
        </loadData>
    </changeSet>
</databaseChangeLog>

3.1.2 數(shù)據(jù)操作與查詢

text存儲json的數(shù)據(jù)操作與查詢與普通text操作無差別

@Service
public class AccountServiceImpl implements AccountService {
    @Autowired
    private AccountMapper accountMapper;

    public void createAccount(Account account) {
        account.setUsername(UUID.randomUUID().toString().replace("-", ""));
        this.accountMapper.insert(account);
    }

    public Account updateAccount(Account account) {
        this.accountMapper.updateById(account);
        return this.accountMapper.selectById(account.getId());
    }

    @Override
    public List<Account> listAll() {
        return this.accountMapper.selectList(Wrappers.emptyWrapper());
    }
}

效果:

3.2 使用json字段(mysql數(shù)據(jù)庫)

3.2.1 建表語句

使用liquibase管理建表語句

  • MySQL使用版本: 大于等于5.7
<?xml version="1.1" encoding="UTF-8" standalone="no"?>
<databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog" xmlns:ext="http://www.liquibase.org/xml/ns/dbchangelog-ext" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog-ext http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-ext.xsd http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.5.xsd">

    <changeSet author="demo" id="account.createTable">
        <createTable tableName="account" remarks="賬號表">
            <!--設置id自增 起始位置從10000 每次加1-->
            <column name="id" remarks="賬戶ID" type="bigint" autoIncrement="true" incrementBy="1" startWith="10000">
                <constraints primaryKey="true" nullable="false"/>
            </column>
            <!--用戶名增加唯一索引-->
            <column name="username" remarks="用戶名" type="VARCHAR(32)">
                <constraints nullable="false" unique="true" uniqueConstraintName="uniq_username"/>
            </column>
            <column name="password" remarks="密碼" type="VARCHAR(32)"/>
            <column name="name" remarks="姓名" type="VARCHAR(20)"/>
            <column name="sex" remarks="性別" type="CHAR(1)"/>
            <column name="phone" remarks="手機" type="VARCHAR(100)"/>
            <column name="email" remarks="郵件" type="VARCHAR(100)"/>
            <column name="create_time" remarks="創(chuàng)建時間" type="datetime(0)"/>
            <column name="update_time" remarks="修改時間" type="datetime(0)"/>
            <column name="extend_json" remarks="拓展字段使用" type="json"/>
        </createTable>
    </changeSet>

    <!--loadData:加載 csv 文件到已存在的表中-->
    <changeSet author="easy-log-demo" id="account.loadData" >
        <loadData tableName="account" file="db/liquibase/csv/account.csv" >
        </loadData>
    </changeSet>


</databaseChangeLog>

3.2.2 數(shù)據(jù)操作與查詢

mysql支持json類型因此借助特定的語法可以實現(xiàn)json精確查詢及模糊查詢

@Service
public class AccountServiceImpl implements AccountService {
    
    @Autowired
    private AccountMapper accountMapper;
    
    public void createAccount(Account account) {
        account.setUsername(UUID.randomUUID().toString().replace("-", ""));
        this.accountMapper.insert(account);
    }

    public Account updateAccount(Account account) {
        this.accountMapper.updateById(account);

        return this.accountMapper.selectById(account.getId());
    }

    /**
     * json 數(shù)據(jù)模糊查詢
     * @param key extend_json 中的json的key
     * @param value extend_json 中的json的key對應value
     * @return
     */
    public List<Account> listByJsonLike(String key, String value) {
//        QueryChainWrapper<Account> queryWrapper = new QueryChainWrapper<>(this.accountMapper);
        LambdaQueryWrapper<Account> queryWrapper = Wrappers.<Account>lambdaQuery();

        //json字段模式查詢
        queryWrapper.apply("JSON_EXTRACT(extend_json, '$." + key + "') LIKE {0}", "%" + value + "%")
                .ge(Account::getId, 10000);
        return this.accountMapper.selectList(queryWrapper);

    }

    /**
     * json 數(shù)據(jù)精確查詢
     * @param key extend_json 中的json的key
     * @param value extend_json 中的json的key對應value
     * @return
     */
    public List<Account> listByJsonEquals(String key, String value) {
        LambdaQueryWrapper<Account> queryWrapper = Wrappers.<Account>lambdaQuery();
        //json字段精確查詢
        queryWrapper.apply("JSON_EXTRACT(extend_json, '$." + key + "') = {0}", value);
        return this.accountMapper.selectList(queryWrapper);

    }

    @Override
    public List<Account> listAll() {
        return this.accountMapper.selectList(Wrappers.emptyWrapper());
    }
}
  • 效果:測試json內(nèi)部字段模糊查詢

4. 附錄

4.1 MySQL JSON索引用法

TODO MySQLJSON索引用法介紹

4.2 mybatis-plus json查詢用法

public class YourService {

    @Autowired
    private YourMapper yourMapper;

    public YourEntity getByJsonKey(String key, String value) {
        QueryWrapper&lt;YourEntity&gt; queryWrapper = Wrappers.&lt;YourEntity&gt;lambdaQuery()
                .apply("json_data-&gt;'$.key' = {0}", value);

        return yourMapper.selectOne(queryWrapper);
    }
}

在上述示例中,.apply(“json_data->‘$.key’ = {0}”, value) 中的 {0} 將會被 MyBatis-Plus 自動處理為預編譯參數(shù),保證了 SQL 的安全性。

請確保你的 MyBatis-Plus 版本支持 .apply() 方法,該方法可以用于執(zhí)行自定義的 SQL 查詢條件。

5. 參考文檔

總結 

到此這篇關于SpringBoot mybatis-plus使用json字段的文章就介紹到這了,更多相關mybatis-plus使用json字段內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Jmail發(fā)送郵件工具類分享

    Jmail發(fā)送郵件工具類分享

    這篇文章主要為大家分享了Jmail發(fā)送郵件工具類,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Spring+Quartz實現(xiàn)動態(tài)任務調(diào)度詳解

    Spring+Quartz實現(xiàn)動態(tài)任務調(diào)度詳解

    這篇文章主要介紹了Spring+Quartz實現(xiàn)動態(tài)任務調(diào)度詳解,最近經(jīng)常基于spring?boot寫定時任務,并且是使用注解的方式進行實現(xiàn),分成的方便將自己的類注入spring容器,需要的朋友可以參考下
    2024-01-01
  • MyBatis 使用權威指南

    MyBatis 使用權威指南

    MyBatis 是支持定制化 SQL、存儲過程以及高級映射的優(yōu)秀的持久層框架。MyBatis 避免了幾乎所有的 JDBC 代碼和手動設置參數(shù)以及獲取結果集,本文給大家介紹MyBatis 使用指南,一起看看吧
    2017-03-03
  • Java concurrency之AtomicLongFieldUpdater原子類_動力節(jié)點Java學院整理

    Java concurrency之AtomicLongFieldUpdater原子類_動力節(jié)點Java學院整理

    AtomicLongFieldUpdater可以對指定"類的 'volatile long'類型的成員"進行原子更新。它是基于反射原理實現(xiàn)的。下面通過本文給大家分享Java concurrency之AtomicLongFieldUpdater原子類的相關知識,感興趣的朋友一起看看吧
    2017-06-06
  • Java程序執(zhí)行過程及內(nèi)存機制詳解

    Java程序執(zhí)行過程及內(nèi)存機制詳解

    本講將介紹Java代碼是如何一步步運行起來的,還會介紹Java程序所占用的內(nèi)存是被如何管理的:堆、棧和方法區(qū)都各自負責存儲哪些內(nèi)容,感興趣的朋友跟隨小編一起看看吧
    2020-12-12
  • Spring Data Jpa實現(xiàn)自定義repository轉(zhuǎn)DTO

    Spring Data Jpa實現(xiàn)自定義repository轉(zhuǎn)DTO

    這篇文章主要介紹了Spring Data Jpa實現(xiàn)自定義repository轉(zhuǎn)DTO,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-08-08
  • spring?boot教程之建立第一個HelloWorld

    spring?boot教程之建立第一個HelloWorld

    這篇文章主要介紹了spring?boot教程之建立第一個HelloWorld的相關資料,需要的朋友可以參考下
    2022-08-08
  • java讀取properties文件的方法實例分析

    java讀取properties文件的方法實例分析

    這篇文章主要介紹了java讀取properties文件的方法,實例分析了java讀取在項目中與不在項目中properties文件的相關技巧,需要的朋友可以參考下
    2015-06-06
  • 詳解JDK自帶javap命令反編譯class文件和Jad反編譯class文件(推薦使用jad)

    詳解JDK自帶javap命令反編譯class文件和Jad反編譯class文件(推薦使用jad)

    這篇文章主要介紹了JDK自帶javap命令反編譯class文件和Jad反編譯class文件(推薦使用jad),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09
  • IDEA的spring項目使用@Qualifier飄紅問題及解決

    IDEA的spring項目使用@Qualifier飄紅問題及解決

    這篇文章主要介紹了IDEA的spring項目使用@Qualifier飄紅問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11

最新評論