热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mysql反向匹配子串_MySQL字符串截取相关函数小结

文中给大家介绍MySQL字符串截取相关函数,具体内容如下所示:在工作中,可能需要将某些字段按某个分割符组成一个字符串作为字段值存取到数据库

文中给大家介绍MySQL 字符串截取相关函数,具体内容如下所示:

在工作中,可能需要将某些字段按某个分割符组成一个字符串作为字段值存取到数据库表中,比如某个任务对应三个结果,分别存储在不同的数据表中,这时可以将这三个不同表的主键按照约定的顺序进行组合(主键a:主键b:主键c)。当需要分别去查任务对应类别的详情信息时,可以截取特定位置的字符串(主键b) join 表b进行操作。正好最近也遇到这块操作,特意将 MySQL 字符串截取的相关函数做一个梳理,以便今后回顾。

一、left(str, len)

返回字符串 str 自左数的 len 个字符。如果任一参数为 NULL,则返回 NULL。

mysql> select left('shinejaie', 5);

+---------------------------------------------------------+

| left('shinejaie', 5) |

+---------------------------------------------------------+

| shine |

+---------------------------------------------------------+

1 row in set (0.00 sec)

二、right(str, len)

返回 str 右边末 len 位的字符。如果有的参数是 NULL 值,则返回 NULL。

mysql> select right('shinejaie', 4);

+---------------------------------------------------------+

| right('shinejaie', 4) |

+---------------------------------------------------------+

| jaie |

+---------------------------------------------------------+

1 row in set (0.00 sec)

三、substring_index(str, delim, count)

返回 str 中第 count 次出现的分隔符 delim 之前的子字符串。如果 count 为正数,将最后一个分隔符左边(因为是从左数分隔符)的所有内容作为子字符串返回;如果 count 为负值,返回最后一个分隔符右边(因为是从右数分隔符)的所有内容作为子字符串返回。在寻找分隔符时,函数对大小写是敏感的。如果在字符串 str 中找不到 delim 参数指定的值,就返回整个字符串。

mysql> select substring_index('home.cnblogs.com', '.', 2);

+---------------------------------------------------------+

| substring_index('home.cnblogs.com', '.', 2) |

+---------------------------------------------------------+

| home.cnblogs |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select substring_index('home.cnblogs.com', '/', 2);

+---------------------------------------------------------+

| substring_index('home.cnblogs.com', '/', 2) |

+---------------------------------------------------------+

| home.cnblogs.com |

+---------------------------------------------------------+

1 row in set (0.00 sec)

四、substring() 与 substr() ---> substring(str, pos)、substring(str from pos)、substring(str, pos, len)、substring(str from pos for len)

在以上4种函数变种形式中,没有 len 参数的函数形式会返回自 str 中位置 pos 处之后的子字符串;有 len 参数的函数形式会返回自 str 中位置 pos 处之后,长度为 len 的子字符串。使用 FROM 的函数形式则是采用的标准的 SQL 语法。pos 参数也可能取负值,在这种情况下,取字符串的方式是从字符串 str 的末尾向前(而非从前往后),从这种逆向顺序的 pos 处开始取字符串。另外,负值的 pos 参数可用于任何形式的 substring() 函数中。

mysql> select substring('shinejaie', 6);

+---------------------------------------------------------+

| substring('shinejaie',6) |

+---------------------------------------------------------+

| jaie |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select substr('shinejaie' from 6);

+---------------------------------------------------------+

| substr('shinejaie' from 6) |

+---------------------------------------------------------+

| jaie |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select substring('shinejaie', -9, 5);

+---------------------------------------------------------+

| substring('shinejaie', -9, 5) |

+---------------------------------------------------------+

| shine |

+---------------------------------------------------------+

1 row in set (0.00 sec)

五、trim([{both | leading | trailing} [remstr] form] str)

将字符串 str去除 remstr 所指定的前缀或后缀,返回结果字符串。如果没有指定标识符both、leading,或trailing,则默认采用 both,即将前后缀都删除。remstr 其实是个可选参数,如果没有指定它,则删除的是空格。

mysql> select trim(' shinejaie ');

+---------------------------------------------------------+

| trim(' shinejaie ') |

+---------------------------------------------------------+

| shinejaie |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select trim(leading 'cn_' from 'cn_shinejaiecn_');

+---------------------------------------------------------+

| trim(leading 'cn_' from 'cn_shinejaiecn_') |

+---------------------------------------------------------+

| shinejaiecn_ |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select trim(both 'cn_' from 'cn_shinejaiecn_');

+---------------------------------------------------------+

| trim(both 'cn_' from 'cn_shinejaiecn_') |

+---------------------------------------------------------+

| shinejaie |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select trim(trailing 'cn_' from 'cn_shinejaiecn_');

+---------------------------------------------------------+

| trim(trailing 'cn_' from 'cn_shinejaiecn_') |

+---------------------------------------------------------+

| cn_shinejaie |

+---------------------------------------------------------+

1 row in set (0.00 sec)

总结

以上所述是小编给大家介绍的MySQL 字符串截取相关函数小结,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!



推荐阅读
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 本文深入探讨了MySQL中的高级特性,包括索引机制、锁的使用及管理、以及如何利用慢查询日志优化性能。适合有一定MySQL基础的读者进一步提升技能。 ... [详细]
  • 如何将955万数据表的17秒SQL查询优化至300毫秒
    本文详细介绍了通过优化SQL查询策略,成功将一张包含955万条记录的财务流水表的查询时间从17秒缩短至300毫秒的方法。文章不仅提供了具体的SQL优化技巧,还深入探讨了背后的数据库原理。 ... [详细]
  • 在使用mybatis进行mapper.xml测试的时候发生必须为元素类型“mapper”声明属性“namespace”的错误项目目录结构UserMapper和UserMappe ... [详细]
  • Java连接MySQL数据库的方法及测试示例
    本文详细介绍了如何安装MySQL数据库,并通过Java编程语言实现与MySQL数据库的连接,包括环境搭建、数据库创建以及简单的查询操作。 ... [详细]
  • 本文介绍了MySQL窗口函数的基本概念、应用场景及常见函数的使用方法。窗口函数在处理复杂查询时非常有用,例如计算每个用户的订单排名、环比增长率、以及动态聚合等。 ... [详细]
  • 解决ADODB连接Access时出现80004005错误的方法
    本文详细介绍了如何解决在使用ADODB连接Access数据库时遇到的80004005错误,包括错误原因分析和具体的解决步骤。 ... [详细]
  • binlog2sql,你该知道的数据恢复工具
    binlog2sql,你该知道的数据恢复工具 ... [详细]
  • 本文详细解析了MySQL中常见的几种错误,并提供了具体的解决方法,帮助开发者快速定位和解决问题。 ... [详细]
  • 本文详细介绍了在Linux操作系统上安装和部署MySQL数据库的过程,包括必要的环境准备、安装步骤、配置优化及安全设置等内容。 ... [详细]
  • 本文详细探讨了在Web开发中常见的UTF-8编码问题及其解决方案,包括HTML页面、PHP脚本、MySQL数据库以及JavaScript和Flash应用中的乱码问题。 ... [详细]
  • PHP面试题精选及答案解析
    本文精选了新浪PHP笔试题及最新的PHP面试题,并提供了详细的答案解析,帮助求职者更好地准备PHP相关的面试。 ... [详细]
  • 本文探讨了在SQL Server 2008环境下,当尝试删除拥有数据库架构的用户时遇到的问题及解决方案,包括如何查询和更改架构所有权。 ... [详细]
  • 七大策略降低云上MySQL成本
    在全球经济放缓和通胀压力下,降低云环境中MySQL数据库的运行成本成为企业关注的重点。本文提供了一系列实用技巧,旨在帮助企业有效控制成本,同时保持高效运作。 ... [详细]
  • 本文详细介绍了Hibernate中的立即检索与延迟检索的概念及区别,同时探讨了类级别与关联级别的检索配置方法。通过具体的配置示例,帮助开发者更好地理解和应用这些策略。 ... [详细]
author-avatar
luosj
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有