mysql에는 json 유형이 있습니다. MySQL은 버전 5.7부터 JSON 데이터를 직접 조작할 수 있는 JSON 데이터 유형을 도입했지만, MySQL 버전 5.7 이하에서는 JSON 형식 데이터를 테이블에 저장하려면 varchar 또는 텍스트와 같은 데이터 유형에 의존해야 합니다.
MySQL
json의 JSON 유형은 매우 사용하기 쉬운 데이터 유형입니다. mysql5.7 이전에는 문자열을 사용하여 json을 저장했지만 이후에는 json을 실행할 수 없다는 문제가 있습니다. 5.7에서는 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를 확인하는 방법은 무엇입니까?
;
개인적으로 저는 람다와 같은 방법을 사용하는 것을 선호합니다. 결국 이것은 세련되고 아름다운 작업입니다.
SELECT content_json->'$.bill[*].bill[*].uuid' from b WHERE JSON_CONTAINS(content_json->'$.bill[*].bill[*].uuid' ,'["cfd872541b3b4507a50c2b2eda6bef28"]')
Query results
코드 분석:
content_json->'$.bill[]. bill [].uuid';
는 content_json 필드를 나타냅니다.
"$"는 객체를 나타내는 필수 기호 포인트입니다.
*는 모두를 나타냅니다.
그러면 코드의 의미는 모든 청구서(두 번째)를 쿼리한다는 것입니다. content_json 필드에서) uuid는 배열로 반환됩니다.
where가 뒤에 오는 조건은 하나 또는 여러 개가 될 수 있음을 의미합니다.
JSON_CONTAINS(필드, 매개변수)
필드는 지정되어야 합니다. 확인할 값 예: content_json->'$.bill[].bill[].uuid' ;
매개변수는 json 유형 문자열이어야 하며 이는 허용되지 않습니다.
추천 튜토리얼: mysql 비디오 튜토리얼
위 내용은 mysql에 json 유형이 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!