Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

MySQL - 특정 번호가 포함된 경우 모든 레코드를 선택하시겠습니까?

<시간/>

특정 번호의 모든 레코드를 선택하려면 MySQL에서 FIND_IN_SET()을 사용하십시오.

테이블을 만들어 봅시다 -

예시

mysql> create table demo73 -> ( -> interest_id varchar(100), -> interest_name varchar(100) -> );쿼리 OK, 영향을 받는 행 0개(1.48

insert 명령을 사용하여 일부 레코드를 테이블에 삽입하십시오 -

예시

mysql> insert into demo73 values("100,101,103,105","SSC");Query OK, 1행 영향(0.34mysql> insert into demo73 values("105,103,1005,1003,104","Computer");Query OK, 1행 영향(0.10mysql> insert into demo73 values("110,105,104,111","Novel");Query OK, 1행 영향(0.31
)

select 문을 사용하여 테이블의 레코드 표시 -

예시

mysql> select *from demo73;

이것은 다음과 같은 출력을 생성합니다 -

출력

+-----------------------+---------------+| 관심 아이디 | 관심 이름 |+-----------------------+--------------+| 100,101,103,105 | SSC || 105,103,1005,1003,104 | 컴퓨터 || 110,105,104,111 | 소설 |+-----------------------+---------------+3행 세트(0.00 

다음은 특정 숫자를 포함하는 경우 모든 레코드를 선택하는 쿼리입니다 -

예시

mysql> select *from demo73 where find_in_set("103",interest_id)> 0;

이것은 다음과 같은 출력을 생성합니다 -

출력

+-----------------------+---------------+| 관심 아이디 | 관심 이름 |+-----------------------+--------------+| 100,101,103,105 | SSC || 105,103,1005,1003,104 | 컴퓨터 |+-----------------------+---------------+2행 세트(0.00초) )