<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
後端動態列設計與實現三部曲,這是最後一步,使用java語言,結合mybatis-plus神技操作json欄位。
簡單介紹下mybatis-plus,大廠中mybatis使用的非常多,而mybatis-plus是基於mybatis做了擴充套件,進一步增強,在不影響資料儲存的情況下,簡化操作方式。有興趣的朋友可以去官網瞭解:https://www.baomidou.com/
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": "青島"}');
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; }
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> { }
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()); } }
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欄位內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45