Mybatis-plus操作json字段實戰教程

後端動態列設計與實現三部曲,這是最後一步,使用java語言,結合mybatis-plus神技操作json字段。

簡單介紹下mybatis-plus,大廠中mybatis使用的非常多,而mybatis-plus是基於mybatis做瞭擴展,進一步增強,在不影響數據存儲的情況下,簡化操作方式。有興趣的朋友可以去官網瞭解:https://www.baomidou.com/

1、架構圖

2、功能

3、表結構

DROP TABLE IF EXISTS user;
CREATE TABLE user(
  id BIGINT(20) NOT NULL COMMENT '主鍵ID',
  name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
  age INT(11) NULL DEFAULT NULL COMMENT '年齡',
  email VARCHAR(50) NULL DEFAULT NULL COMMENT '郵箱',
  wallet VARCHAR(3000) NULL DEFAULT NULL COMMENT '錢包',
  other_info VARCHAR(3000) NULL DEFAULT NULL COMMENT '其他信息',
  PRIMARY KEY (id)
);


INSERT INTO user (id, name, age, email, wallet, other_info) VALUES
(1, 'Jone', 18, '[email protected]', '{"name": "支付寶錢包","currencyList": [{"type": "USD","amount": 999.19},{"type": "RMB","amount": 1000.19}]}', '{"sex": "男","city": "南昌"}'),
(2, 'Jack', 20, '[email protected]', '{"name": "微信錢包","currencyList": [{"type": "USD","amount": 888.18},{"type": "RMB","amount": 1000.18}]}', '{"sex": "男","city": "青島"}');
INSERT INTO user (id, name, age, email, wallet, other_info) VALUES
(1, 'Jone', 18, '[email protected]', '{"name": "支付寶錢包","currencyList": [{"type": "USD","amount": 999.19},{"type": "RMB
(2, 'Jack', 20, '[email protected]', '{"name": "微信錢包","currencyList": [{"type": "USD","amount": 888.18},{"type": "RMB","amount": 1000.18}]}', '{"sex": "男","city": "青島"}');

4、實體定義 

package com.baomidou.mybatisplus.samples.typehandler.entity;

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.extension.handlers.FastjsonTypeHandler;
import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
import lombok.Data;
import lombok.experimental.Accessors;
/**用戶實體對應表 user
 * @author hubin
 * @since 2018-08-11
 */
@Data
@Accessors(chain = true)
@TableName(autoResultMap = true)
public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;

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


    @TableField(typeHandler = FastjsonTypeHandler.class)
    private OtherInfo otherInfo;
}
package com.baomidou.mybatisplus.samples.typehandler.entity;
import java.util.List;
import lombok.Data;

/**
 * 錢包
 */
@Data
public class Wallet {
    /**
     * 名稱
     */
    private String name;
    /**
     * 各種貨幣
     */
    private List<Currency> currencyList;
}
package com.baomidou.mybatisplus.samples.typehandler.entity;

import lombok.Data;

/**
 * 貨幣
 */
@Data
public class Currency {
    /**
     * 類型: 人民幣 RMB , 美元 USD
     */
    private String type;
    /**
     * 金額
     */
    private Double amount;
}
package com.baomidou.mybatisplus.samples.typehandler.entity;
import lombok.Data;

/**
 * 其他信息
 */
@Data
public class OtherInfo {
    /**
     * 性別
     */
    private String sex;
    /**
     * 居住城市
     */
    private String city;
}

5、Dao定義 

package com.baomidou.mybatisplus.samples.typehandler.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.samples.typehandler.entity.User;

/**
 * <p>
 * MP 支持不需要 UserMapper.xml 這個模塊演示內置 CRUD 咱們就不要 XML 部分瞭
 * </p>
 *
 * @author hubin
 * @since 2018-08-11
 */
public interface UserMapper extends BaseMapper<User> {
}

6、類型轉換器

package com.baomidou.mybatisplus.samples.typehandler.config;
import com.baomidou.mybatisplus.extension.handlers.GsonTypeHandler;
import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.gson.Gson;
import org.springframework.boot.CommandLineRunner;
import org.springframework.stereotype.Component;

/**
 * @author miemie
 * @since 2019-11-28
 */
@Component
public class MpJsonConfig implements CommandLineRunner {

    /**
     * 可以set進去自己的
     */
    @Override
    public void run(String... args) throws Exception {
        JacksonTypeHandler.setObjectMapper(new ObjectMapper());
        GsonTypeHandler.setGson(new Gson());
    }
}

 7、測試

package com.baomidou.mybatisplus.samples.typehandler;
import javax.annotation.Resource;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import com.baomidou.mybatisplus.samples.typehandler.entity.User;
import com.baomidou.mybatisplus.samples.typehandler.mapper.UserMapper;

/**
 * <p>
 * 內置 類型處理器 演示
 * </p>
 *
 * @author hubin
 * @since 2018-08-11
 */
@RunWith(SpringRunner.class)
@SpringBootTest
public class SampleTest {

    @Resource
    private UserMapper userMapper;

    /**
     * 自定義類型處理器演示參考 mybatis-plus-sample-deluxe 模塊
     */
    @Test
    public void test() {
        User Jone = userMapper.selectById(1);
        System.out.println(Jone);
        System.err.println(Jone.getName());

        User Jack = userMapper.selectById(1);
        System.err.println(Jack.getName());
    }
}​​​​​

結果如下:

2020-11-22 12:46:58.164  INFO 3168 — [           main] c.b.m.samples.typehandler.SampleTest     : Started SampleTest in 4.125 seconds (JVM running for 5.707)
2020-11-22 12:46:58.477 DEBUG 3168 — [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==>  Preparing: SELECT id,name,age,email,wallet,other_info FROM user WHERE id=?
2020-11-22 12:46:58.509 DEBUG 3168 — [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==> Parameters: 1(Integer)
2020-11-22 12:46:58.713 DEBUG 3168 — [           main] c.b.m.s.t.mapper.UserMapper.selectById   : <==      Total: 1
User(id=1, name=Jone, age=18, [email protected], wallet=Wallet(name=支付寶錢包, currencyList=[Currency(type=USD, amount=999.19), Currency(type=RMB, amount=1000.19)]), otherInfo=OtherInfo(sex=男, city=南昌))
2020-11-22 12:46:58.715 DEBUG 3168 — [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==>  Preparing: SELECT id,name,age,email,wallet,other_info FROM user WHERE id=?
2020-11-22 12:46:58.715 DEBUG 3168 — [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==> Parameters: 2(Integer)
2020-11-22 12:46:58.716 DEBUG 3168 — [           main] c.b.m.s.t.mapper.UserMapper.selectById   : <==      Total: 1
User(id=2, name=Jack, age=20, [email protected], wallet=Wallet(name=微信錢包, currencyList=[Currency(type=USD, amount=888.18), Currency(type=RMB, amount=1000.18)]), otherInfo=OtherInfo(sex=男, city=青島))
2020-11-22 12:46:58.736  INFO 3168 — [extShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 – Shutdown initiated…
2020-11-22 12:46:58.747  INFO 3168 — [extShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 – Shutdown c

總結,使用mybatis-plus可以提高應用程序操作數據庫的效率,讓開發人員專註於業務邏輯實現。在使用mybatis-plus操作json字段的要點主要有:

1、在需要處理的字段上使用@TableField(typeHandler = JacksonTypeHandler.class),同時實體開啟@TableName(autoResultMap = true)

2、註冊工具類,MpJsonConfig.

mybatis-plus 還有許多很好用的功能,感興趣的朋友可以自己去官網上下看,也可能從github或者gitee上拉取最新代碼,瞭解它的工作原理,結合自己的業務做一些增強。

到此這篇關於Mybatis-plus操作json字段實戰教程的文章就介紹到這瞭,更多相關Mybatis-plus操作json字段內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: