乱码乱a∨中文字幕,在线免费激情视频,亚洲欧美久久夜夜潮,国产在线网址

  1. <sub id="hjl7n"></sub>

    1. <sub id="hjl7n"></sub>

      <legend id="hjl7n"></legend>

      當前位置:首頁 >  站長 >  數據庫 >  正文

      Mysql查詢JSON結果的相關函數匯總

       2020-11-27 15:06  來源: 腳本之家   我來投稿 撤稿糾錯

        阿里云優(yōu)惠券 先領券再下單

      這篇文章主要介紹了Mysql 查詢 JSON 結果的相關函數匯總,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下

      JSON 格式字段是 Mysql 5.7 新加的屬性,不夠它本質上以字符串性質保存在庫中的,剛接觸時我只了解 $.xx 查詢字段的方法,因為大部分時間,有這個就夠了,其他交給程序就行了,但是最近一些操作需要更復雜的查詢操作,所以趕緊了解下更多的方法。

      JSON_EXTRACT(json_doc [,path])

      查詢字段

      mysql> set @j = '{"name":"wxnacy"}';
      mysql> select JSON_EXTRACT(@j, '$.name');
      +----------------------------+
      | JSON_EXTRACT(@j, '$.name') |
      +----------------------------+
      | "wxnacy"   |
      +----------------------------+

      還有一種更簡潔的方式,但是只能在查詢表時使用

      mysql> select ext -> '$.name' from test;
      +-----------------+
      | ext -> '$.name' |
      +-----------------+
      | "wxnacy" |
      +-----------------+

      在 $. 后可以正常的使用 JSON 格式獲取數據方式,比如數組

      mysql> set @j = '{"a": [1, 2]}';
      mysql> select JSON_EXTRACT(@j, '$.a[0]');
      +----------------------------+
      | JSON_EXTRACT(@j, '$.a[0]') |
      +----------------------------+
      | 1    |
      +----------------------------+

      JSON_DEPTH(json_doc)

      計算 JSON 深度,計算方式 {} [] 有一個符號即為一層,符號下有數據增加一層,復雜 JSON 算到最深的一次為止,官方文檔說 null 值深度為 0,但是實際效果并非如此,列舉幾個例子

      JSON_LENGTH(json_doc [, path])

      計算 JSON 最外層或者指定 path 的長度,標量的長度為1。數組的長度是數組元素的數量,對象的長度是對象成員的數量。

      mysql> SELECT JSON_LENGTH('[1, 2, {"a": 3}]');
      +---------------------------------+
      | JSON_LENGTH('[1, 2, {"a": 3}]') |
      +---------------------------------+
      |    3 |
      +---------------------------------+
      mysql> SELECT JSON_LENGTH('{"a": 1, "b": {"c": 30}}');
      +-----------------------------------------+
      | JSON_LENGTH('{"a": 1, "b": {"c": 30}}') |
      +-----------------------------------------+
      |     2 |
      +-----------------------------------------+
      mysql> SELECT JSON_LENGTH('{"a": 1, "b": {"c": 30}}', '$.b');
      +------------------------------------------------+
      | JSON_LENGTH('{"a": 1, "b": {"c": 30}}', '$.b') |
      +------------------------------------------------+
      |      1 |
      +------------------------------------------------+

      JSON_TYPE(json_doc)

      返回一個utf8mb4字符串,指示JSON值的類型。 這可以是對象,數組或標量類型,如下所示:

      mysql> SET @j = '{"a": [10, true]}';
      mysql> SELECT JSON_TYPE(@j);
      +---------------+
      | JSON_TYPE(@j) |
      +---------------+
      | OBJECT |
      +---------------+
      mysql> SELECT JSON_TYPE(JSON_EXTRACT(@j, '$.a'));
      +------------------------------------+
      | JSON_TYPE(JSON_EXTRACT(@j, '$.a')) |
      +------------------------------------+
      | ARRAY    |
      +------------------------------------+
      mysql> SELECT JSON_TYPE(JSON_EXTRACT(@j, '$.a[0]'));
      +---------------------------------------+
      | JSON_TYPE(JSON_EXTRACT(@j, '$.a[0]')) |
      +---------------------------------------+
      | INTEGER    |
      +---------------------------------------+
      mysql> SELECT JSON_TYPE(JSON_EXTRACT(@j, '$.a[1]'));
      +---------------------------------------+
      | JSON_TYPE(JSON_EXTRACT(@j, '$.a[1]')) |
      +---------------------------------------+
      | BOOLEAN    |
      +---------------------------------------+

      可能的返回類型

      純JSON類型:

      OBJECT:JSON對象

      ARRAY:JSON數組

      BOOLEAN:JSON真假文字

      NULL:JSON null文字

      數字類型:

      INTEGER:MySQL TINYINT,SMALLINT,MEDIUMINT以及INT和BIGINT標量

      DOUBLE:MySQL DOUBLE FLOAT標量

      DECIMAL:MySQL DECIMAL和NUMERIC標量

      時間類型:

      DATETIME:MySQL DATETIME和TIMESTAMP標量

      日期:MySQL DATE標量

      TIME:MySQL TIME標量

      字符串類型:

      STRING:MySQL utf8字符類型標量:CHAR,VARCHAR,TEXT,ENUM和SET

      二進制類型:

      BLOB:MySQL二進制類型標量,包括BINARY,VARBINARY,BLOB和BIT

      所有其他類型:

      OPAQUE(原始位)

      JSON_VALID

      返回0或1以指示值是否為有效JSON。 如果參數為NULL,則返回NULL。

      mysql> SELECT JSON_VALID('{"a": 1}');
      +------------------------+
      | JSON_VALID('{"a": 1}') |
      +------------------------+
      |   1 |
      +------------------------+
      mysql> SELECT JSON_VALID('hello'), JSON_VALID('"hello"');
      +---------------------+-----------------------+
      | JSON_VALID('hello') | JSON_VALID('"hello"') |
      +---------------------+-----------------------+
      |   0 |   1 |
      +---------------------+-----------------------+

      以上就是Mysql 查詢JSON結果的相關函數匯總的詳細內容,更多關于MySQL json函數的資料請關注腳本之家其它相關文章!

      來源:腳本之家

      鏈接:https://www.jb51.net/article/199677.htm

      申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點子。點擊此處,共同探討創(chuàng)業(yè)新機遇!

      相關文章

      • MySQL5.7 集群配置的步驟

        這篇文章主要介紹了MySQL5.7集群配置的步驟,幫助大家更好的理解和學習使用MySQL,感興趣的朋友可以了解下

        標簽:
        mysql
      • MySQL中觸發(fā)器和游標的介紹與使用

        這篇文章主要給大家介紹了關于MySQL中觸發(fā)器和游標的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

        標簽:
        mysql
      • MySQL中exists、in及any的基本用法

        這篇文章主要給大家介紹了關于MySQL中exists、in及any的基本用法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

        標簽:
        mysql
      • MySQL正確修改最大連接數的3種方案

        這篇文章主要給大家介紹了關于MySQL正確修改最大連接數的3種方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

        標簽:
        mysql
      • 教你怎么在Windows系統(tǒng)上手動搭建MySql數據庫

        1.已經購買好的騰訊云輕量應用服務器。2.作者本次演示使用的系統(tǒng)是WindowsServer2019,其他windows版本也可以,操作流程大同小異。3.使用Windows遠程桌面連接騰訊云輕量服務器。

      熱門排行

      信息推薦