문자열에 특수 문자가 포함되어 있는지 검색하려면 REGEXP를 사용할 수 있습니다. 다음은 구문입니다 -
select * from yourTableName where yourColumnName REGEXP '[^a-zA-Z0-9]';
먼저 테이블을 생성하겠습니다 -
mysql> create table specialCharactersDemo -> ( -> StudentId varchar(100) -> ); Query OK, 0 rows affected (0.58 sec)
insert 명령을 사용하여 테이블에 레코드를 삽입합니다. 다음은 쿼리입니다 -
mysql> insert into specialCharactersDemo values('STU_1234'); Query OK, 1 row affected (0.15 sec) mysql> insert into specialCharactersDemo values('STU567'); Query OK, 1 row affected (0.14 sec) mysql> insert into specialCharactersDemo values('STU#1234'); Query OK, 1 row affected (0.13 sec) mysql> insert into specialCharactersDemo values('STU897$'); Query OK, 1 row affected (0.18 sec) mysql> insert into specialCharactersDemo values('STU999'); Query OK, 1 row affected (0.43 sec) mysql> insert into specialCharactersDemo values('STU1010'); Query OK, 1 row affected (0.14 sec)
다음은 select 문을 사용하여 테이블의 모든 레코드를 표시하는 쿼리입니다 -
mysql> select *from specialCharactersDemo;
이것은 다음과 같은 출력을 생성합니다 -
+-----------+ | StudentId | +-----------+ | STU_1234 | | STU567 | | STU#1234 | | STU897$ | | STU999 | | STU1010 | +-----------+ 6 rows in set (0.00 sec)
문자열에 특수 문자가 포함되어 있는지 검색하는 쿼리는 다음과 같습니다. -
mysql> select *from specialCharactersDemo -> where StudentId REGEXP '[^a-zA-Z0-9]';
이것은 다음과 같은 출력을 생성합니다 -
+-----------+ | StudentId | +-----------+ | STU_1234 | | STU#1234 | | STU897$ | +-----------+ 3 rows in set (0.02 sec)
위의 결과에 대해 다른 구문을 사용할 수 있습니다. 다음은 쿼리입니다 -
mysql> select *from specialCharactersDemo -> where StudentId REGEXP'[^[:alnum:]]';
이것은 다음과 같은 출력을 생성합니다 -
+-----------+ | StudentId | +-----------+ | STU_1234 | | STU#1234 | | STU897$ | +-----------+ 3 rows in set (0.05 sec)