mysql 조회표 필드에 xx 내용이 포함되어 있는지 여부

949 단어 mysql
mysql 조회표 필드에 xx 내용이 포함되어 있는지 여부
장면: 데이터베이스 모 테이블의 콘텐츠 섹션에 저장된 것은 json 문자열이고 팀 필드는 그룹 그룹이며 json 문자열에도 팀의 값을 저장한다.데이터베이스에 두 개의 값이 다른 데이터가 포함되어 있는지 검사하다
mysql에서find 사용하기in_set 함수,
MySQL 매뉴얼 중findin_set 함수의 구문:FINDIN_SET(str,strlist)
str가 조회할 문자열 strlist 필드 이름 매개 변수는 "이고,"(1,2,6,8) 조회 필드 (strlist) 에 포함된 결과를 구분하여 null 또는 기록으로 되돌려줍니다.
만약 문자열str가 N 서브체인으로 구성된 문자열 목록strlist에 있다면, 되돌아오는 값의 범위는 1에서 N 사이입니다.문자열 목록은 ',' 기호로 분리된 하위 사슬로 구성된 문자열입니다.첫 번째 매개변수가 상수 문자열이고 두 번째 type SET 열이면 FINDIN_SET() 함수가 최적화되어 비트 계산을 사용합니다.str가 strlist에 없거나 strlist가 빈 문자열이면 되돌아오는 값은 0입니다.매개 변수가 NULL이면 값이 NULL으로 반환됩니다.이 함수는 첫 번째 매개 변수에 쉼표 (',') 를 포함할 때 정상적으로 실행되지 않습니다.
실례sql
SELECT * from user_files a WHERE NOT EXISTS (
	select * from user_files b where a.user_file_id = b.user_file_id and FIND_IN_SET(CONCAT('"team":"',a.team,'"'),b.content)
) and a.team IS not NULL;

좋은 웹페이지 즐겨찾기