<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
我這裡沒有建立json的欄位格式,而是使用了text儲存json 。
注意:用JSON型別的話1)JSON列儲存的必須是JSON格式資料,否則會報錯。2)JSON資料型別是沒有預設值的。
插入json格式的資料到這一列中:
{"age": "28", "pwd": "lisi", "name": "李四"}
1、
select * from `offcn_off_main` where json_extract(json_field,"$.name") = '李四'
2、
select * from `offcn_off_main` where json_field->'$.name' = '李四'
使用explain可以檢視到無法使用索引。
所以需要修改:
mysql原生並不支援json列中的屬性索引,但是我們可以通過mysql的虛擬列間接的為json中的某些屬性建立索引,原理就是為json中的屬性建立虛擬列,然後通過給虛擬列建立索引,從而間接的給屬性建立了索引。
在MySQL 5.7中,支援兩種Generated Column,即Virtual Generated Column和Stored Generated Column,前者只將Generated Column儲存在資料字典中(表的後設資料),並不會將這一列資料持久化到磁碟上;後者會將Generated Column持久化到磁碟上,而不是每次讀取的時候計算所得。很明顯,後者存放了可以通過已有資料計算而得的資料,需要更多的磁碟空間,與Virtual Column相比並沒有優勢----(其實我覺得還是有優勢畢竟會少一些查詢計算)
因此,MySQL 5.7中,不指定Generated Column的型別,預設是Virtual Column。
如果需要Stored Generated Golumn的話,可能在Virtual Generated Column上建立索引更加合適,一般情況下,都使用Virtual Generated Column,這也是MySQL預設的方式。
格式如下:
fieldname <type> [ GENERATED ALWAYS ] AS ( <expression> ) [ VIRTUAL|STORED ] [ UNIQUE [KEY] ] [ [PRIMARY] KEY ] [ NOT NULL ] [ COMMENT <text> ]
所以我這裡:
ALTER TABLE 'off_main' `names_virtual` VARCHAR(20) GENERATED ALWAYS AS (`json_field` ->> '$.name') not null;
Note: 利用操作符-» 來參照JSON欄位中的KEY。在本例中欄位names_virtual為虛擬欄位,我把它定義成不可以為空。在實際的工作中,一定要集合具體的情況來定。因為JSON本身是一種弱結構的資料物件。也就是說的它的結構不是固定不變的。
給虛擬欄位增加索引:
CREATE INDEX `names` ON `off_main`(`names_virtual`);
注意如果虛擬欄位並不是建立表是新增的,而是後面加的,增加索引時如果有的行中虛擬欄位為null,但是又設定了它不能為null,那麼索引無法建立成功,提示column can not be null.
增加索引後 explain看下即可看到用到了索引,並且虛擬欄位的值會隨著json欄位的屬性修改而自動變化。
update off_main set json_field = json_set(json_field,'$.phone', '132') WHERE id = 45 //同時修改多個 UPDATE offcn_off_main set json_field = json_set(json_field,'$.name',456,'$.age','bbb') WHERE id = 45
json_set() 方法存在的則會覆蓋,不存在的會新增。
UPDATE offcn_off_main set json_field = json_remove(json_field,'$.pwd','$.phone') WHERE id = 45
UPDATE offcn_off_main set json_field = json_insert(json_field,'$.pwd','111') WHERE id = 45
insert與update不同之處在於insert不存在的會增加,存在的不會覆蓋
1.如果資料量小的話,將json資料直接複製到mysql的json欄位中,如果資料過大可以通過java等後臺形式對json資料解析,然後寫入資料庫中。
查詢操作
select *,json->'$.features[0].geometry.rings' as rings from JSON;
從一張表讀取一部分資料存入另一張表中(一條資料)
insert into DT_village(name, border) SELECT json->'$.features[0].attributes.CJQYMC',json->'$.features[0].geometry.rings' from JSON;
讀取json資料並寫入資料庫(此時使用的是定義函數的形式來執行方法,可以定義便量)
#清空資料庫 TRUNCATE table DT_village; #定義儲存過程 delimiter // DROP PROCEDURE IF EXISTS insert_test_val; ##num_limit 要插入資料的數量,rand_limit 最大隨機的數值 CREATE PROCEDURE insert_test_val() BEGIN DECLARE i int default 0; DECLARE a,b varchar(5000); WHILE i<10 do set a=CONCAT('$.features[',i,'].attributes.CJQYMC'); set b=CONCAT('$.features[',i,'].geometry.rings'); insert into DT_village(name, border) select #json->'$.features[0].attributes.CJQYMC',json->'$.features[0].geometry.rings' # (json->a),(json->b) json_extract(json,a),json_extract(json,b) from JSON; set i = i + 1; END WHILE; END // #呼叫儲存過程 call insert_test_val();
呼叫遊標的方式獲取jsosn資料中的一行,並執行插入操作
delimiter // drop procedure if exists StatisticStore; CREATE PROCEDURE StatisticStore() BEGIN #建立接收遊標資料的變數 declare j json;#儲存json資料 DECLARE i int default 0; #建立總數變數,記錄執行次數,控制迴圈 DECLARE a,b,c varchar(5000);#定義json陣列中的某個資料的鍵值 #建立結束標誌變數 declare done int default false; #建立遊標 declare cur cursor for select json from JSON where name = '1'; #指定遊標迴圈結束時的返回值 declare continue HANDLER for not found set done = true; #設定初始值 set a=CONCAT('$.features[',i,'].attributes.XZQDM'); set b=CONCAT('$.features[',i,'].attributes.XZQMC'); set c=CONCAT('$.features[',i,']'); #開啟遊標 open cur; #開始迴圈遊標裡的資料 read_loop:loop #根據遊標當前指向的一條資料 fetch cur into j; #判斷遊標的迴圈是否結束 if done then leave read_loop;#跳出遊標迴圈 end if; #這裡可以做任意你想做的操作 WHILE i<11 do insert into dt_border(xzq_code,name,border) select json_extract(j,a),json_extract(j,b),json_extract(j,c) from JSON; set i = i + 1; END WHILE; #結束遊標迴圈 end loop; #關閉遊標 close cur; #輸出結果 select j,i; END; #呼叫儲存過程 call StatisticStore();
以上為個人經驗,希望能給大家一個參考,也希望大家多多支援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