再见西城 发表于 2015-1-16 22:13:09

MYSQL教程之MYSQL形式婚配:REGEXP和like用法

对于现有业务,可以轻松移植到MySQL。当你需要替换掉老的硬件,当你需要削减历史遗留下的老系统的时候,选用MySQL对于财务部门来说更具吸引力。</p>like请求全部数据都要婚配,而REGEXP只必要部分婚配便可。
也就是说,用Like,必需这个字段的一切内容满意前提,而REGEXP只必要有任何一个片断满意便可。
MySQL供应尺度的SQL形式婚配(like),和一种基于象Unix有用程序如vi、grep和sed的扩大正则表达式形式婚配的格局(regexp)。
SQL的形式婚配同意你利用“_”婚配任何单个字符,而“%”婚配恣意数量字符(包含零个字符)。在MySQL中,SQL的形式缺省是疏忽巨细写的。上面显现一些例子。注重在你利用SQL形式时,你不克不及利用=或!=;而利用LIKE或NOTLIKE对照操纵符。
为了找出以“b”开首的名字:
mysql>SELECT*FROMpetWHEREnameLIKE"b%";
+--------+--------+---------+------+------------+------------+
nameownerspeciessexbirthdeath
+--------+--------+---------+------+------------+------------+
BuffyHarolddogf1989-05-13NULL
BowserDianedogm1989-08-311995-07-29
+--------+--------+---------+------+------------+------------+
为了找出以“fy”开头的名字:
mysql>SELECT*FROMpetWHEREnameLIKE"%fy";
+--------+--------+---------+------+------------+-------+
nameownerspeciessexbirthdeath
+--------+--------+---------+------+------------+-------+
FluffyHaroldcatf1993-02-04NULL
BuffyHarolddogf1989-05-13NULL
+--------+--------+---------+------+------------+-------+
为了找出包括一个“w”的名字:
mysql>SELECT*FROMpetWHEREnameLIKE"%w%";
+----------+-------+---------+------+------------+------------+
nameownerspeciessexbirthdeath
+----------+-------+---------+------+------------+------------+
ClawsGwencatm1994-03-17NULL
BowserDianedogm1989-08-311995-07-29
WhistlerGwenbirdNULL1997-12-09NULL
+----------+-------+---------+------+------------+------------+
为了找出包括恰好5个字符的名字,利用“_”形式字符:
mysql>SELECT*FROMpetWHEREnameLIKE"_____";
+-------+--------+---------+------+------------+-------+
nameownerspeciessexbirthdeath
+-------+--------+---------+------+------------+-------+
ClawsGwencatm1994-03-17NULL
BuffyHarolddogf1989-05-13NULL
+-------+--------+---------+------+------------+-------+

别的一种婚配是基于正则表达式的。当你对这类形式举行婚配测试时,利用REGEXP和NOTREGEXP操纵符(或RLIKE和NOTRLIKE,它们是同义词)。
“.”婚配任何单个的字符。
一个字符类“[...]”婚配在方括号内的任何字符。比方,“”婚配“a”、“b”或“c”。为了定名字符的一个局限,利用一个“-”。“”婚配任何小写字母,而“”婚配任何数字。
“*”婚配零个或多个在它后面的器材。比方,“x*”婚配任何数目的“x”字符,“*”婚配的任何数目的数字,而“.*”婚配任何数目的任何器材。
正则表达式是辨别巨细写的,可是假如你但愿,你能利用一个字符类婚配两种写法。比方,“”婚配小写或年夜写的“a”而“”婚配两种写法的任何字母。
假如它呈现在被测试值的任何中央,形式就婚配(只需他们婚配全部值,SQL形式婚配)。
为了定位一个形式以便它必需婚配被测试值的入手下手或开头,在形式入手下手处利用“^”或在形式的开头用“$”。
为了申明扩大正则表达式怎样事情,下面所示的LIKE查询鄙人面利用REGEXP重写:
为了找出以“b”开首的名字,利用“^”婚配名字的入手下手而且“”婚配小写或年夜写的“b”:
mysql>SELECT*FROMpetWHEREnameREGEXP"^";
+--------+--------+---------+------+------------+------------+
nameownerspeciessexbirthdeath
+--------+--------+---------+------+------------+------------+
BuffyHarolddogf1989-05-13NULL
BowserDianedogm1989-08-311995-07-29
+--------+--------+---------+------+------------+------------+
为了找出以“fy”开头的名字,利用“$”婚配名字的开头:
mysql>SELECT*FROMpetWHEREnameREGEXP"fy$";
+--------+--------+---------+------+------------+-------+
nameownerspeciessexbirthdeath
+--------+--------+---------+------+------------+-------+
FluffyHaroldcatf1993-02-04NULL
BuffyHarolddogf1989-05-13NULL
+--------+--------+---------+------+------------+-------+
为了找出包括一个“w”的名字,利用“”婚配小写或年夜写的“w”:
mysql>SELECT*FROMpetWHEREnameREGEXP"";
+----------+-------+---------+------+------------+------------+
nameownerspeciessexbirthdeath
+----------+-------+---------+------+------------+------------+
ClawsGwencatm1994-03-17NULL
BowserDianedogm1989-08-311995-07-29
WhistlerGwenbirdNULL1997-12-09NULL
+----------+-------+---------+------+------------+------------+

这一切听起来不错,无疑DBaaS具有很多相对于RDBMS的优势。然而MySQL学习教程,DBaaS也有其局限性,云服务中固有的局限性就是之一。当客户开始将数据放入云端时,他们会遭遇到无法控制的网络性能问题。

第二个灵魂 发表于 2015-1-18 23:24:09

你可以简单地认为适合的就是好,不适合就是不好。

小魔女 发表于 2015-1-24 23:45:48

这是一个不错的新特性。虽然索引的附加字段没有索引键值效率高,但是相对映射到数据表中效率还是提高了很多。我做过试验,在我的实验环境中会比映射到表中提高30%左右的效率。

愤怒的大鸟 发表于 2015-2-2 16:26:39

代替了原来VB式的错误判断。比Oracle高级不少。

再现理想 发表于 2015-2-8 01:40:48

无法深入到数据库系统层面去了解和探究

不帅 发表于 2015-2-23 23:11:35

换言之,只有在不断的失败中尝试成功,而关于失败的总结却是很少的

灵魂腐蚀 发表于 2015-3-7 10:25:41

其实可以做一下类比,Oracle等数据库产品老早就支持了java编程,而且提供了java池参数作为用户配置接口。但是现在有哪些系统大批使用了java存储过程?!连Oracle自己的应用都不用为什么?!

金色的骷髅 发表于 2015-3-21 16:32:08

你觉得我的非分区索引无法对起子分区,你可以提醒我一下呀!没有任何的提醒,直接就变成了非分区表。不知道这算不算一个bug。大家也可以试试。
页: [1]
查看完整版本: MYSQL教程之MYSQL形式婚配:REGEXP和like用法