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

다른 열 값에서 여러 단어를 검색하는 단일 MySQL 쿼리

<시간/>

이를 위해 여러 LIKE와 함께 WHERE 절을 사용할 수 있습니다. 먼저 테이블을 생성하겠습니다 -

mysql> create table DemoTable1536
   -> (
   -> Sentence text
   -> );
Query OK, 0 rows affected (0.51 sec)

삽입 명령을 사용하여 테이블에 일부 레코드 삽입 -

mysql> insert into DemoTable1536 values('I like MySQL database.');
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable1536 values('Java is an Object Oriented Programming Language');
Query OK, 1 row affected (0.30 sec)
mysql> insert into DemoTable1536 values('I only like data structure');
Query OK, 1 row affected (0.21 sec)
mysql> insert into DemoTable1536 values('MongoDB is NoSQL database');
Query OK, 1 row affected (0.46 sec)

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

mysql> select * from DemoTable1536;

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

+--------------------------------------------------+
| Sentence                                         |
+--------------------------------------------------+
| I like MySQL database.                           |
| Java is an Object Oriented Programming Language  |
| I only like data structure                       |
| MongoDB is NoSQL database                        |
+--------------------------------------------------+
4 rows in set (0.00 sec)

다음은 여러 단어를 검색하는 쿼리입니다 -

mysql> select * from DemoTable1536
   -> where ( Sentence like '%like%') or (Sentence like '%database%') or (Sentence like '%data%');

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

+----------------------------+
| Sentence                   |
+----------------------------+
| I like MySQL database.     |
| I only like data structure |
| MongoDB is NoSQL database  |
+----------------------------+
3 rows in set (0.00 sec)