[mysql] JSON数据操作

/ 20,536评论 / 88765阅读 / 0点赞

前言

在MySql中使用

声明json类型的字段

create table test(
    uids json not null default ('[]')
);
default ('[{"name":"coolight"}, {"name","洛天依"}]')
或
default ("[{'name':'coolight'}, {'name','洛天依'}]")

Mysql中常用的操作json函数

JSON_LENGTH(json1)=JSON_LENGTH(json2) and JSON_CONTAINS(json1, json2)
// 例如:
update test set enable=true where JSON_LENGTH(json1)=JSON_LENGTH(json2) and JSON_CONTAINS(json1, json2);
// 示例:在数组末尾追加元素
SELECT JSON_ARRAY_APPEND('[1, 2, 3]', '$', 4); 
// 得到 [1,2,3,4]

// 示例:对数组添加一个元素,如果已经存在则不添加
// ["1000000", "1000001", "1000002"]
update test set uids=json_array_append(uids, '$','1000001') where id=777 and JSON_CONTAINS(uids,JSON_ARRAY('1000001'))=0;
// 没有添加,注意where ... and 后面 使用JSON_CONTAINS判断了是否包含准备添加的元素
// ["1000000", "1000001", "1000002"]
update test set uids=json_remove(uids, JSON_UNQUOTE(JSON_SEARCH(uids, 'one','1000001'))) where id=777;
// ["1000000", "1000002"]
create TRIGGER auto_reset after insert on test for each row
BEGIN
    update test set uids=json_array_append(uids, '$', CAST(NEW.uid as char)) where id=NEW.id;
END;
  1. Gdmxqp说道:

    order azipro for sale omnacortil oral buy generic gabapentin 100mg

  2. ThomasLiz说道:

    Pharmacie en ligne fiable п»їpharmacie en ligne Pharmacie en ligne France

  3. Archiecaf说道:

    https://pharmacieenligne.icu/# acheter mГ©dicaments Г  l’Г©tranger

  4. Prodst说道:

    purchase isotretinoin online cheap accutane usa buy zithromax online

  5. Uolxns说道:

    brand cefdinir order cefdinir 300 mg online prevacid for sale

  6. Seedly说道:

    viagra vs.levitra 100mg viagra strongest viagra pill

  7. Voiqqb说道:

    buy modafinil medication provigil cost prednisone 40mg tablet

  8. Dennislyhok说道:

    reputable mexican pharmacies online: buying prescription drugs in mexico – buying prescription drugs in mexico

  9. Tprwfy说道:

    cenforce medication buy cenforce generic aralen cost

  10. Dennislyhok说道:

    escrow pharmacy canada: canadian pharmacy in canada – best rated canadian pharmacy

  11. Pnzcur说道:

    cialis sale cialis on line sildenafil mail order

  12. Yczviq说道:

    buy telmisartan 80mg buy movfor generic order molnunat

  13. Stangamn说道:

    cialis for daily use cialis com how long does it take for cialis 20mg to work

  14. Hmaxpq说道:

    prilosec pill metoprolol 50mg cost buy lopressor pill

  15. Xcwbva说道:

    buy premarin without prescription buy premarin pills for sale order sildenafil

  16. Wizfld说道:

    where to buy betahistine without a prescription order haldol 10mg order benemid pills

  17. FrancisFrold说道:

    india pharmacy mail order: india pharmacy – india pharmacy

  18. Fafsgr说道:

    buy generic latanoprost buy capecitabine 500 mg generic rivastigmine generic

  19. gegine说道:

    cialis medicine click here cheapest cialis 20 mg

  20. FrancisFrold说道:

    medicine in mexico pharmacies: mexico drug stores pharmacies – mexican pharmaceuticals online

  21. Ancfle说道:

    vasotec price bicalutamide pill how to get duphalac without a prescription

  22. launda说道:

    how fast does cialis work buy cialis cialis com coupons

  23. Xufuuu说道:

    pyridostigmine pills order pyridostigmine 60mg generic rizatriptan tablet

  24. Cncqbx说道:

    ferrous sulfate 100mg us how to buy ferrous buy betapace 40mg without prescription

  25. Hrzykj说道:

    purchase prasugrel without prescription order prasugrel 10 mg online order tolterodine 2mg generic

  26. pousia说道:

    buy sildenafil online generic for viagra viagra prescription online

  27. Qkltfr说道:

    order etodolac 600 mg for sale order mebeverine 135 mg online cheap order pletal 100 mg generic

  28. Nbhudy说道:

    florinef 100 mcg pills imodium 2mg drug buy generic loperamide

  29. Georgespado说道:

    online shopping pharmacy india: reputable indian pharmacies – reputable indian pharmacies

  30. Gaubybup说道:

    the taste of a ripe mango is a tropical delight duck All truths are easy to understand once they are discovered; the point is to discover them

  31. Gaubybup说道:

    pantyhose and heels are an interesting choice of attire for the beach google street view in asia Progress always involves risks. You can’t steal second base and keep your foot on first

  32. LloydKed说道:

    http://mexicanpharmacy.guru/# mexican drugstore online

  33. Govlml说道:

    buy dydrogesterone 10 mg generic januvia 100 mg canada order empagliflozin 25mg sale

  34. Georgeoptor说道:

    https://misoprostol.guru/# buy cytotec online fast delivery

  35. Michaelununk说道:

    http://lipitor.pro/# lipitor simvastatin

  36. Cpmdic说道:

    meloset 3mg over the counter danazol 100 mg usa capsules danazol

  37. Xsbvee说道:

    order dipyridamole 25mg pills plendil 5mg tablet buy generic pravachol

  38. Michaelununk说道:

    http://lisinopril.pro/# zestril brand name

  39. Georgeoptor说道:

    http://ciprofloxacin.ink/# cipro for sale

  40. Michaelununk说道:

    https://avodart.pro/# cheap avodart prices

  41. Georgeoptor说道:

    https://lipitor.pro/# generic lipitor price

  42. Michaelununk说道:

    http://misoprostol.guru/# buy misoprostol over the counter

  43. Georgeoptor说道:

    https://ciprofloxacin.ink/# ciprofloxacin over the counter

  44. DavidVoR说道:

    https://ed-pills.men/# erectile dysfunction medicines

  45. Myhsxr说道:

    order aspirin 75 mg pill order imiquimod without prescription buy zovirax

  46. RobertBog说道:

    best online doctor for antibiotics: cheapest antibiotics – buy antibiotics online

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注