|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
对于现有业务,可以轻松移植到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,它们是同义词)。
“.”婚配任何单个的字符。
一个字符类“[...]”婚配在方括号内的任何字符。比方,“[abc]”婚配“a”、“b”或“c”。为了定名字符的一个局限,利用一个“-”。“[a-z]”婚配任何小写字母,而“[0-9]”婚配任何数字。
“*”婚配零个或多个在它后面的器材。比方,“x*”婚配任何数目的“x”字符,“[0-9]*”婚配的任何数目的数字,而“.*”婚配任何数目的任何器材。
正则表达式是辨别巨细写的,可是假如你但愿,你能利用一个字符类婚配两种写法。比方,“[aA]”婚配小写或年夜写的“a”而“[a-zA-Z]”婚配两种写法的任何字母。
假如它呈现在被测试值的任何中央,形式就婚配(只需他们婚配全部值,SQL形式婚配)。
为了定位一个形式以便它必需婚配被测试值的入手下手或开头,在形式入手下手处利用“^”或在形式的开头用“$”。
为了申明扩大正则表达式怎样事情,下面所示的LIKE查询鄙人面利用REGEXP重写:
为了找出以“b”开首的名字,利用“^”婚配名字的入手下手而且“[bB]”婚配小写或年夜写的“b”:
mysql>SELECT*FROMpetWHEREnameREGEXP"^[bB]";
+--------+--------+---------+------+------------+------------+
nameownerspeciessexbirthdeath
+--------+--------+---------+------+------------+------------+
BuffyHarolddogf1989-05-13NULL
BowserDianedogm1989-08-311995-07-29
+--------+--------+---------+------+------------+------------+
为了找出以“fy”开头的名字,利用“$”婚配名字的开头:
mysql>SELECT*FROMpetWHEREnameREGEXP"fy$";
+--------+--------+---------+------+------------+-------+
nameownerspeciessexbirthdeath
+--------+--------+---------+------+------------+-------+
FluffyHaroldcatf1993-02-04NULL
BuffyHarolddogf1989-05-13NULL
+--------+--------+---------+------+------------+-------+
为了找出包括一个“w”的名字,利用“[wW]”婚配小写或年夜写的“w”:
mysql>SELECT*FROMpetWHEREnameREGEXP"[wW]";
+----------+-------+---------+------+------------+------------+
nameownerspeciessexbirthdeath
+----------+-------+---------+------+------------+------------+
ClawsGwencatm1994-03-17NULL
BowserDianedogm1989-08-311995-07-29
WhistlerGwenbirdNULL1997-12-09NULL
+----------+-------+---------+------+------------+------------+
这一切听起来不错,无疑DBaaS具有很多相对于RDBMS的优势。然而MySQL学习教程,DBaaS也有其局限性,云服务中固有的局限性就是之一。当客户开始将数据放入云端时,他们会遭遇到无法控制的网络性能问题。 |
|