深入了解MySQL字符串比较函数

MySQL字符串比较函数函数我们经常会用到,下面就对MySQL字符串比较函数的用法作了很详细的介绍分析,希望对您学习MySQL字符串比较函数方面能有所启迪。

根据,MySQL 会自动将数字转化为字符串,反之亦然。

mysql> SELECT 1+”1”;-> 2mysql> SELECT CONCAT(2,” test”);-> ”2 test”

若想要将数字明确地转化为字符串,可使用 CAST()或 CONCAT()函数:

mysql> SELECT 38.8, CAST(38.8 AS CHAR);-> 38.8, ”38.8”mysql> SELECT 38.8, CONCAT(38.8);-> 38.8, ”38.8”

CAST() 比较可取。

若已经对一个字符串函数给定一个二进制字符串作为参数, 则所得到的结果字符串也是一个二进制字符串。一个转化为字符串的数字被作为二进制字符串对待。这仅会对比较结果产生影响。

一般而言, 若字符串比较中任意一个表达式是区分大小写的,则执行比较时也区分大小写。

◆ expr LIKE pat [ESCAPE ”escape-char”]

模式匹配,使用SQL简单正规表达式比较。返回1 (TRUE) 或 0 (FALSE)。 若 expr 或 pat 中任何一个为 NULL,则结果为 NULL。

模式不需要为文字字符串。例如,可以被指定为一个字符串表达式或表列。

在模式中可以同LIKE一起使用以下两种通配符:

 

 

mysql> SELECT ”David!” LIKE ”David_”;-> 1mysql> SELECT ”David!” LIKE ”%D%v%”;-> 1

若要对通配符的文字实例进行检验, 可将转义字符放在该字符前面。如果没有指定 ESCAPE字符, 则假设为‘\’。

 

 

mysql> SELECT ”David!” LIKE ”David\_”;-> 0mysql> SELECT ”David_” LIKE ”David\_”;-> 1

要指定一个不同的转义字符,可使用ESCAPE语句:

mysql> SELECT ”David_” LIKE ”David|_” ESCAPE ”|”;-> 1

转义序列可以为空,也可以是一个字符的长度。 从 MySQL 5.1.2开始, 如若 NO_BACKSLASH_ESCAPES SQL模式被激活, 则该序列不能为空。

以下两个语句举例说明了字符串比较不区分大小写,除非其中一个操作数为二进制字符串:

mysql> SELECT ”abc” LIKE ”ABC”;-> 1mysql> SELECT ”abc” LIKE BINARY ”ABC”;-> 0

在MySQL中, LIKE 允许出现在数字表达式中。 (这是标准SQL LIKE 的延伸)。

mysql> SELECT 10 LIKE ”1%”;-> 1

注释: 由于 MySQL在字符串中使用 C转义语法(例如, 用‘ ’代表一个换行字符),在LIKE字符串中,必须将用到的‘\’双写。例如, 若要查找 ‘ ’, 必须将其写成 ‘’。而若要查找 ‘\’, 则必须将其写成 it as ‘\\\\’;原因是反斜线符号会被语法分析程序剥离一次,在进行模式匹配时,又会被剥离一次,最后会剩下一个反斜线符号接受匹配。

◆ expr NOT LIKE pat [ESCAPE ”escape-char”]

这相当于 NOT (expr LIKE pat [ESCAPE ”escape-char”])。

◆ expr NOT REGEXP pat expr NOT RLIKE pat

这相当于NOT (expr REGEXP pat)。

◆ expr REGEXP pat expr RLIKE pat

执行字符串表达式 expr 和模式pat 的模式匹配。该模式可以被延伸为正规表达式。正规表达式的语法在附录G:MySQL正则表达式中有详细讨论。若expr 匹配 pat,则返回 1; 否则返回0。若 expr 或 pat 任意一个为 NULL, 则结果为 NULL。 RLIKE 是REGEXP的同义词, 作用是为mSQL 提供兼容性。

模式不需要为文字字符串。例如,可以被指定为一个字符串表达式或表列。

注释:由于在字符串中, MySQL使用 C 转义语法 (例如, 用‘ ’来代表换行字符 ),在REGEXP字符串中必须将用到的‘\’ 双写。

REGEXP 不区分大小写, 除非将其同二进制字符串同时使用。

mysql> SELECT ”Monty!” REGEXP ”m%y%%”;-> 0mysql> SELECT ”Monty!” REGEXP ”.*”;-> 1mysql> SELECT ”new* *line” REGEXP ”new\\*.\\*line”;-> 1mysql> SELECT ”a” REGEXP ”A”, ”a” REGEXP BINARY ”A”;-> 1 0mysql> SELECT ”a” REGEXP ”^[a-d]”;-> 1

在确定字符类型时,REGEXP 和 RLIKE 使用当前字符集 (默认为cp1252 Latin1 )。 警告:这些操作符不支持多字节字元。

◆ STRCMP(expr1,expr2)

若所有的字符串均相同,则返回STRCMP(),若根据当前分类次序,第一个参数小于第二个,则返回 -1,其它情况返回 1 。

mysql> SELECT STRCMP(”text”, ”text2”);-> -1mysql> SELECT STRCMP(”text2”, ”text”);-> 1mysql> SELECT STRCMP(”text”, ”text”);-> 0

在执行比较时,STRCMP() 使用当前字符集。这使得默认的比较区分大小写,当操作数中的一个或两个都是二进制字符串时除外。

 

 

【编辑推荐】

MySQL大表重复字段的查询方法

mysql查询语句中distinct的问题

教您如何实现MySQL全文查询

MySQL查询结果条数编号示例

MySQL查询中间记录的方法

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/243350.html<

(0)
运维的头像运维
上一篇2025-04-25 05:38
下一篇 2025-04-25 05:40

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注