从 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.