博客
关于我
MySQL学习笔记.查询数据3
阅读量:517 次
发布时间:2019-03-07

本文共 1891 字,大约阅读时间需要 6 分钟。

MySQL 正则表达式查询指南

开头匹配

正则表达式中的 ^ 符号用于匹配字符串的开头。以下是如何利用这一符号进行查询的示例:

1. 查询以 x 开头的记录

SELECT * FROM fruits WHERE f_name REGEXP '^x';

此查询会返回所有以 x 开头的记录。例如,xxxxxbabay 都会匹配。

2. 查询以 xx 开头的记录

SELECT * FROM fruits WHERE f_name REGEXP '^xx';

此查询会筛选出以 xx 开头的记录。例如,只有 xxxx 会被选中。

结尾匹配

正则表达式中的 $ 符号用于匹配字符串的结尾。以下是如何利用这一符号进行查询的示例:

1. 查询以 e 结尾的记录

SELECT * FROM fruits WHERE f_name REGEXP 'e$';

此查询会返回所有以 e 结尾的记录。例如,appleorangegrape 都会被包含在结果中。

2. 查询以 go 结尾的记录

SELECT * FROM fruits WHERE f_name REGEXP 'go$';

此查询会筛选出以 go 结尾的记录。例如,只有 mngo 会被选中。

任意字符匹配

正则表达式中的 . 符号匹配任意一个字符。以下是如何利用这一符号进行查询的示例:

1. 查询包含 ry 的记录

SELECT * FROM fruits WHERE f_name REGEXP 'r.y';

此查询会返回所有包含 ry 中任意一个的记录。例如,blackberryberrycherry 都会被包含。

重复字符匹配

正则表达式中的 * 符号匹配零个或多个重复的字符。+ 符号则表示至少一个重复的字符。

1. 查询以 mn 开头的记录(允许多个 n

SELECT * FROM fruits WHERE f_name REGEXP '^mn*';

此查询会返回所有以 mn 开头,后面可以有零个或多个 n 的记录。例如,melonmngo 都会被包含。

2. 查询以 mn 开头的记录(至少一个 n

SELECT * FROM fruits WHERE f_name REGEXP '^mn+';

此查询会返回所有以 mn 开头,后面至少有一个 n 的记录。例如,只有 mngo 会被选中。

字符串匹配

正则表达式可以通过直接指定字符串来匹配特定的文本。以下是如何进行查询的示例:

1. 查询包含 ge 的记录

SELECT * FROM fruits WHERE f_name REGEXP 'ge';

此查询会返回所有包含 ge 的记录。例如,orange 会被包含。

2. 查询包含 gena 的记录

SELECT * FROM fruits WHERE f_name REGEXP 'ge|na';

此查询会返回所有包含 gena 的记录。例如,orangebanana 都会被包含。

特定字符匹配

正则表达式中的 [] 用于匹配字符集合中的任意一个字符。以下是如何利用这一符号进行查询的示例:

1. 查询包含 ae 的记录

SELECT * FROM fruits WHERE f_name REGEXP '[ae]';

此查询会返回所有包含 ae 的记录。例如,appleapricotblackberry 等都会被包含。

重复字符串匹配

正则表达式中的 {} 用于指定字符的重复次数。以下是如何利用这一符号进行查询的示例:

1. 查询至少连续出现两次 r 的记录

SELECT * FROM fruits WHERE f_name REGEXP 'r{2,}';

此查询会返回所有至少包含两次连续 r 的记录。例如,blackberryberrycherry 都会被包含。

排除特定字符

正则表达式中的 [^...] 用于匹配不在指定集合中的字符。以下是如何利用这一符号进行查询的示例:

1. 查询非 101-104 的记录

SELECT * FROM fruits WHERE s_id REGEXP '[^101-104]';

此查询会返回所有不在 101104 之间的 s_id 的记录。例如,103105107 等都会被包含。

总结

通过合理运用正则表达式中的各个符号,可以对数据库中的记录进行精确匹配。从开头到结尾、任意字符到指定字符串,再到字符集合和重复次数的匹配,都可以通过这些符号实现。

转载地址:http://kzfnz.baihongyu.com/

你可能感兴趣的文章
NumPy 或 Pandas:将数组类型保持为整数,同时具有 NaN 值
查看>>
numpy 或 scipy 有哪些可能的计算可以返回 NaN?
查看>>
numpy 数组 dtype 在 Windows 10 64 位机器中默认为 int32
查看>>
numpy 数组与矩阵的乘法理解
查看>>
NumPy 数组拼接方法-ChatGPT4o作答
查看>>
numpy 用法
查看>>
Numpy 科学计算库详解
查看>>
Numpy.fft.fft和numpy.fft.fftfreq有什么不同
查看>>
numpy.linalg.norm(求范数)
查看>>
Numpy.ndarray对象不可调用
查看>>
Numpy.VisibleDeproationWarning:从不整齐的嵌套序列创建ndarray
查看>>
Numpy:按多个条件过滤行?
查看>>
Numpy:条件总和
查看>>
numpy、cv2等操作图片基本操作
查看>>
numpy中的argsort的用法
查看>>
NumPy中的精度:比较数字时的问题
查看>>
numpy判断对应位置是否相等,all、any的使用
查看>>
Numpy多项式.Polynomial.fit()给出的系数与多项式.Polyfit()不同
查看>>
Numpy如何使用np.umprod重写range函数中i的python
查看>>
numpy学习笔记3-array切片
查看>>