>  기사  >  데이터 베이스  >  mysql에 json 유형이 있나요?

mysql에 json 유형이 있나요?

青灯夜游
青灯夜游원래의
2020-10-02 12:03:033487검색

mysql에는 json 유형이 있습니다. MySQL은 버전 5.7부터 JSON 데이터를 직접 조작할 수 있는 JSON 데이터 유형을 도입했지만, MySQL 버전 5.7 이하에서는 JSON 형식 데이터를 테이블에 저장하려면 varchar 또는 텍스트와 같은 데이터 유형에 의존해야 합니다.

mysql에 json 유형이 있나요?

MySQL

json의 JSON 유형은 매우 사용하기 쉬운 데이터 유형입니다. mysql5.7 이전에는 문자열을 사용하여 json을 저장했지만 이후에는 json을 실행할 수 없다는 문제가 있습니다. 5.7에서는 json 데이터를 직접 조작할 수 있습니다.

  1. json 생성에 대해서는 말할 것도 없습니다. 길이를 가져올 필요가 없으며 기본값은 0
  2. 업데이트 및 삽입을 위해 문자열 삽입을 사용할 수 있습니다.
  3. 쿼리는 개인적으로 넘겨주는 것을 좋아하지 않습니다. 데이터는 처리를 위해 백그라운드로 전달되므로 처리를 위해 데이터베이스에 넘겨보겠습니다. 예는 다음과 같습니다.
  4. 데이터베이스의 특정 테이블에는 해당 데이터가 포함된 content_json 필드가 있습니다!
{
  "bill": [
    {
      "bill": [
        {
          "id": "C81AEAD03F90000142E81B405F6FADC0",
          "uuid": "cfd872541b3b4507a50c2b2eda6bef28",
          "billid": "kjdzyljgmzsfzypj",
          "pageno": [],
          "billver": "V1",
          "billname": "新增测试",
          "fjNumber": "",
          "trueName": "",
          "allPageno": [
            {
              "top": 13,
              "left": 7
            }
          ],
          "billValue": {},
          "isOtherZL": "",
          "billNumber": "",
          "fjTMNumber": ""
        },
        {
          "id": "C81AED69D6400001A07818551D9EBEC0",
          "uuid": "05d87c8052cd44209c684407d200b7ec",
          "billid": "opztsfpsgd",
          "pageno": [],
          "billver": "V1",
          "billname": "发票申购",
          "fjNumber": "",
          "trueName": "",
          "allPageno": [
            {
              "top": 13,
              "left": 7
            }
          ],
          "isOtherZL": "",
          "billNumber": "",
          "fjTMNumber": ""
        }
      ],
      "index": "",
      "dependBjBill": {
        "formula": "",
        "keyView": ""
      },
      "codeCondition": {
        "formula": "",
        "keyView": ""
      },
      "billRuleCondition": {
        "formula": "",
        "keyView": ""
      }
    },
    {
      "bill": [
        {
          "id": "C81AED84903000019B29EAB0196014CE",
          "uuid": "0d93fe614d09489cbad8fa5a3d160289",
          "billid": "kjdzcwgwht",
          "pageno": [],
          "billver": "V1",
          "billname": "财务顾",
          "fjNumber": "",
          "trueName": "",
          "allPageno": [
            {
              "top": 39,
              "left": 7
            }
          ],
          "isOtherZL": "",
          "billNumber": "",
          "fjTMNumber": ""
        }
      ],
      "index": "",
      "dependBjBill": {
        "formula": "",
        "keyView": ""
      },
      "codeCondition": {
        "formula": "",
        "keyView": ""
      },
      "billRuleCondition": {
        "formula": "",
        "keyView": ""
      }
    }
  ],
  "questions": [],
  "relyonCondition": {}
}

구조는 이런데, 하단 uuid를 쿼리하고 싶습니다! 조건에 따라 확인하세요 지폐의 하단 부분은 배열입니다. 그러면 내부의 지폐는 여전히 배열입니다. 그러면 하단 uuid를 확인하는 방법은 무엇입니까?
mysql에 json 유형이 있나요?;
개인적으로 저는 람다와 같은 방법을 사용하는 것을 선호합니다. 결국 이것은 세련되고 아름다운 작업입니다.

SELECT content_json->'$.bill[*].bill[*].uuid' 
from  b 
WHERE JSON_CONTAINS(content_json->'$.bill[*].bill[*].uuid' ,'["cfd872541b3b4507a50c2b2eda6bef28"]')

Query resultsmysql에 json 유형이 있나요?

코드 분석:
content_json->'$.bill[]. bill [].uuid';

는 content_json 필드를 나타냅니다.
"$"는 객체를 나타내는 필수 기호 포인트입니다.
*는 모두를 나타냅니다.

그러면 코드의 의미는 모든 청구서(두 번째)를 쿼리한다는 것입니다. content_json 필드에서) uuid는 배열로 반환됩니다.
where가 뒤에 오는 조건은 하나 또는 여러 개가 될 수 있음을 의미합니다.
JSON_CONTAINS(필드, 매개변수)
필드는 지정되어야 합니다. 확인할 값 예: content_json->'$.bill[].bill[].uuid' ;
매개변수는 json 유형 문자열이어야 하며 이는 허용되지 않습니다.

추천 튜토리얼: mysql 비디오 튜토리얼

위 내용은 mysql에 json 유형이 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.