Mysql sql语句回顾2 --正则表达式

在这里简单回顾一下mysql在过滤数据的时候正则表达式的用法,主要是每个用法给一个例子,或者加一些简短的说明。

这里要提前说一下,使用正则表达式过滤数据是用 REGEXP关键字

基本字符匹配:

SELECT prod_name FROM products WHERE prod_name REGEXP ‘1000’;

该查询语句的意思是prod_name字段中包含1000的数据,只要值中的任何部位包含1000都可以

SELECT prod_name FROM products WHERE prod_name REGEXP ‘.000’;

"."代表的是单个字符的通配符,相当于任何单个字符,类似LIKE中的通配符"_"一样,该语句的意思是查询处prod_name字段中包含诸如1000,2000,或者任意一个字符后边跟上000的数据

进行OR匹配:

SELECT prod_name FROM products WHERE prod_name REGEXP ‘1000|2000’;

在这里“|”代表or的意思,也就是“或”的意思,该语句会吧prod_name字段中包含1000或者包含2000或者两个都包含的数据查询出来,or匹配可以给出两个以上的匹配项例如 1000|2000|3000

匹配几个字符之一:

SELECT prod_name FROM products WHERE prod_name REGEXP ‘[123] Ton’;

[]括起来的部分表示匹配其中一个例如 1 Ton ,2 Ton 这样

匹配范围:

SELECT prod_name FROM products WHERE prod_name REGEXP ‘[1-9] Ton’;

如果在上一个例子中[]括起来的部分的字符比较长,而且都是数组,并且数字又是连续的话,可以改成范围匹配,这样sql语句会更加简短一点,当然可以把[1-9]换成[123456789],如果是字母的话可是使用[a-z]这样的方式

匹配特殊字符:

SELECT prod_name FROM products WHERE prod_name REGEXP ‘\\.’;

在mysql中要匹配特殊字符的话需要加上//转义一下才可以,因为特殊字符在sql语句中有特殊的含义

匹配多个实例:

首先需要介绍几个匹配字符

* 0个或者多个匹配

+ 一个或者多个匹配(等于{1,})

? 0个或者一个匹配(等于{0,1})

{n} 指定数目的匹配

{n,} 不少于指定数目的匹配

{n,m} 匹配数目的范围(m不超过255)

SELECT prod_name FROM products WHERE prod_name REGEXP ‘\\([0-9] sticks?\\)’;

在该语句中?匹配它前面的任何字符的0次或者一次出现

定位符:

^ 匹配文本的开始

$ 匹配文本的结尾

[[:<:]] 词的开始

[[:>:]] 词的结尾

SELECT prod_name FROM products WHERE prod_name REGEXP ‘^[0-9\\.]’;

该匹配字符串的意思是只有以.和任意数字为开头的数据被查询

时间: 2024-10-12 23:08:13

Mysql sql语句回顾2 --正则表达式的相关文章

Mysql sql语句回顾1

检索出不存在相同值的列表可以加上DISTINCT关键字 SELECT DISTINCT vend_id FROM products; 可以使用LIMIT子句来限制返回结果的数量 SELECT prod_name FROM products LIMIT 5; LIMIT子句同样拥有offset的功能,就是设定从第几条数据开始获得 SELECT prod_name FROM products LIMIT 5,5; 代表从第五个数据开始的五条数据 虽然LIMIT具有offset的功能,但是Mysql还

快速学习MySQL SQL语句

须知: SQL语言:结构化查询语言,是关系型数据库查询语言的标准,不同的数据库虽然有自己私有扩展,但关键词都支持:(select.update.delete.insert.where) SQL语句分类:像Oracle.MSSQL都是通用的 DDL:数据定义语言(create.alter.drop.rename) DML:数据库维护语言(select.insert.update.delete) DCL:数据库控制语言,权限(Grant.revoke) TCL:事物型语言(commt.sarepqi

mysql sql语句分析

SELECT     a.id    ,b.order_id,b.attr  FROM    tourist_order a     LEFT JOIN order_attr b     ON a.id = b.order_id        AND b.attr='order_status'    WHERE     b.order_id IS NULL    AND a.create_type!=19    AND a.added_time>='2014-01-01'    AND a.si

mysql sql语句大全

1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份数据的 device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' --- 开始 备份 BACKUP DATABASE pubs TO testBack 4.说明:创建新表 cr

第04章 mysql SQL语句

2015-10-24 目录 参考资料 [1] 唐汉明.深入浅出MySQL 数据库开发.优化与管理维护(第2版)[M].北京:人民邮电出版社,2014 [2] Schwartz.高性能MySQL(第3版)[M].北京:电子工业出版社,2013 [3] 范德兰斯.MySQL开发者SQL权威指南 [M].北京:机械工业出版社,2008 [4] Forta.MySQL必知必会 [M].北京:人民邮电出版社,2009 [5] mysql sql语句大全 [6] MySQL 最基本的SQL语法/语句 [7]

最全mysql sql语句大全

mysql sql语句大全 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份数据的 device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' --- 开始 备份 BACKUP DATABASE pubs TO testBac

MYSQL SQL语句技巧初探(一)

MYSQL SQL语句技巧初探(一) 本文是我最近了解到的sql某些方法()组合实现一些功能的总结以后还会更新: rand与rand(n)实现提取随机行及order by原理的探讨. Bit_and,bit_or,bit_count等位操作方法实现统计功能. rand与rand(n)提取 使用order by rand(n)配合limit n可以提起相应的n个随机样本. 如:select  *  from student grade='2' order by rand() limit 5 随机提

MySQL——(SQL语句)

关系型数据库设计范式:     第一范式:当关系模式R的每个关系属性都是不可分的数据项,那么就成R是第一范式的模式(1NF)     简单说法:字段是原子性的     第二范式:党关系模式R是2NF,且关系模式R(U,F)中的所有非主属性对任何候选关键字不存在传递依赖,则称关系R是属于第三范式     简单说法:存在可用主键     第三模式:当关系模式R是2NF,且关系模式R(U,F)中的所有非主属性对任何候选关键字都不存在传递依赖,则称关系R是属于第三方范式     简单说法:任何表都不应该

MySQL sql语句执行顺序

sql语句select语句查询顺序 (7)     SELECT (8)     DISTINCT <select_list> (1)     FROM <left_table> (3)     <join_type> JOIN <right_table> (2)     ON <join_condition> (4)     WHERE <where_condition> (5)     GROUP BY <group_by_