從 MySQL 中獲取首字元不是字母或數字的行?


若要獲取首字元不是字母或數字的行,可以使用以下正則表示式。

案例 1 − 如果你想要獲得那些以數字開頭的行,可以使用以下語法 −

SELECT *FROM yourTableName
WHERE yourColumnName REGEXP '^[0-9]';

案例 2 − 如果你想要獲得那些以字母數字開頭的行,請使用以下語法 −

SELECT *FROM yourTableName
WHERE yourColumnName REGEXP '^[^0-9A-Za-z]' ;

為了理解上述語法,讓我們建立一個表。建立表的查詢如下 −

mysql> create table getRowsFirstNotAlphanumeric
-> (
-> Id int NOT NULL AUTO_INCREMENT,
-> UserPassword varchar(20),
-> PRIMARY KEY(Id)
-> );
Query OK, 0 rows affected (0.61 sec)

使用 insert 命令在表中插入一些記錄。查詢如下 −

mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('@123456');
Query OK, 1 row affected (0.19 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('#7666666');
Query OK, 1 row affected (0.22 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('98876Carol');
Query OK, 1 row affected (0.16 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('$12345Carol');
Query OK, 1 row affected (0.09 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('%David567');
Query OK, 1 row affected (0.10 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('123456Larry');
Query OK, 1 row affected (0.07 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('909Robert');
Query OK, 1 row affected (0.12 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('3333Maxwell');
Query OK, 1 row affected (0.09 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('_123456Bob');
Query OK, 1 row affected (0.10 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('5767676Chris');
Query OK, 1 row affected (0.10 sec)
mysql> insert into getRowsFirstNotAlphanumeric(UserPassword) values('(88883Mike');
Query OK, 1 row affected (0.11 sec)

現在你可以使用 select 語句顯示錶中的所有記錄。查詢如下 −

mysql> select *from getRowsFirstNotAlphanumeric;

以下是輸出 −

+----+--------------+
| Id | UserPassword |
+----+--------------+
| 1 | @123456       |
| 2 | #7666666      |
| 3 | 98876Carol    |
| 4 | $12345Carol   |
| 5 | %David567     |
| 6 | 123456Larry   |
| 7 | 909Robert     |
| 8 | 3333Maxwell   |
| 9 | _123456Bob    |
| 10 | 5767676Chris |
| 11 | (88883Mike   |
+----+--------------+
11 rows in set (0.00 sec)

案例 1 − 以下是獲取所有不以字母數字開頭的行的查詢 −

mysql> SELECT *FROM getRowsFirstNotAlphanumeric
-> WHERE UserPassword REGEXP '^[0-9]';

以下是輸出 −

+----+--------------+
| Id | UserPassword |
+----+--------------+
| 3 | 98876Carol    |
| 6 | 123456Larry   |
| 7 | 909Robert     |
| 8 | 3333Maxwell   |
| 10 | 5767676Chris |
+----+--------------+
5 rows in set (0.00 sec)

案例 2: 以下是獲取所有以字母數字開頭的行的查詢

mysql> SELECT *FROM getRowsFirstNotAlphanumeric
-> WHERE UserPassword REGEXP '^[^0-9A-Za-z]';

以下是輸出

+----+--------------+
| Id | UserPassword |
+----+--------------+
| 1 | @123456       |
| 2 | #7666666      |
| 4 | $12345Carol   |
| 5 | %David567     |
| 9 | _123456Bob    |
| 11 | (88883Mike   |
+----+--------------+
6 rows in set (0.00 sec)

更新日期:30-6 月-2020

531 瀏覽量

職業生涯起航

完成課程即可獲得認證

開始
廣告
© . All rights reserved.