感觉MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用。

函数:

1、从左开始截取字符串

left(str, length)

说明:left(被截取字段,截取长度)

例:select left(content,200) as abstract from my_content_t

2、从右开始截取字符串

right(str, length)

说明:right(被截取字段,截取长度)

例:select right(content,200) as abstract from my_content_t

3、截取字符串

substring(str, pos)

substring(str, pos, length)

说明:substring(被截取字段,从第几位开始截取)

substring(被截取字段,从第几位开始截取,截取长度)

例:select substring(content,5) as abstract from my_content_t

select substring(content,5,200) as abstract from my_content_t

(注:如果位数是负数 如-5 则是从后倒数位数,到字符串结束或截取的长度)

4、按关键字截取字符串

substring_index(str,delim,count)

说明:substring_index(被截取字段,关键字,关键字出现的次数)

例:select subs tring_index("blog.jb51.net","。",2) as abstract from my_content_t

结果:blog.jb51

(注:如果关键字出现的次数是负数 如-2 则是从后倒数,到字符串结束)

函数简介:

SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)

不带有len 参数的格式从字符串str返回一个子字符串,起始于位置 pos。带有len参数的格式从字符串str返回一个长度同len字符相同的子字符串,起始于位置 pos。 使用 FROM的格式为标准 SQL 语法。也可能对pos使用一个负值。假若这样,则子字符串的位置起始于字符串结尾的pos 字符,而不是字符串的开头位置。在以下格式的函数中可以对pos 使用一个负值。

详情请查阅手册。

实例:

表1:user

期望效果:通过user表jlid字段存储的id值,读取jl表中的相应记录,这里想要读取,jl表中id为1、2的记录,首先想到用in,但是很遗憾由于

jlid字段存储的id值有2个,尽管从形式上符合in(1,2)的格式,但是如果你使用select jl.* from jl where jl.id in(select jlid from user where user.id=1)来查询的话,是不行的,他总是返回id为1的记录。

那么怎么办呢?如果我们能够分别得到1,2中的1和2就行了。好在mysql也提供了字符串截取函数SUBSTRING。

sql句法如下:

SELECT jl. *

FROM jl

WHERE jl.id = (

SELECT SUBSTRING( (

SELECT user.jlid

FROM user

WHERE user.id =1

), 1, 1 ) )

OR jl.id = (

SELECT SUBSTRING( (

SELECT user.jlid

FROM user

WHERE user.id =1

), 3, 1 )

)

LIMIT 0 , 30

简单解释一下:

SELECT SUBSTRING( (SELECT user.jlid FROM user WHERE user.id =1), 1, 1 ) )

这里用了子查询,首先查询user表中,id为1的jlid字段的值,返回的是字符串,然后使用SUBSTRING进行截取,得到字符串1

SELECT SUBSTRING( (SELECT user.jlid FROM user WHERE user.id =1), 3, 1 ) )

这条语句得到2

1和2都得到了再通过主查询的where来查询,要注意我们需要查询id=1和id=2的记录,所以用到了OR,怎么样,是不是有点麻烦,

您的第一直觉是不是要用2条sql语句,中间再配合php的explode函数来查询呢?这样想是正常的,但是这两者之间谁的效率高,小编并没有测试,希望有心的你,可以帮忙哦!

如果你想更好的提升你的编程能力,学好C语言C++编程!弯道超车,快人一步!

【C语言C++学习企鹅圈子】,分享(源码、项目实战视频、项目笔记,基础入门教程)

欢迎转行和学习编程的伙伴,利用更多的资料学习成长比自己琢磨更快哦!

编程学习书籍:

编程学习视频:

MySQL字符串是怎么截取substring函数的?相关推荐

  1. mysql 截取第一个字符_MySQL 字符串截取SUBSTRING()函数

    MySQL 字符串截取相关函数: 1.从左开始截取字符串 left(str, length) 说明:left(被截取字段,截取长度) 例: select left(content,200) as ab ...

  2. MySQL 字符串截取SUBSTRING()函数

    1.从左开始截取字符串 left(str, length)  说明:left(被截取字段,截取长度)  例: select left(content,200) as abstract from my_ ...

  3. java提取字符从mysql_MySQL 字符串截取SUBSTRING()函数

    MySQL 字符串截取相关函数: 1.从左开始截取字符串 left(str, length) 说明:left(被截取字段,截取长度) 例: select left(content,200) as ab ...

  4. mybatis学习(21):MySQL 字符串 转换 CAST与CONVERT 函数的用法

    MySQL 的CAST()和CONVERT()函数可用来获取一个类型的值,并产生另一个类型的值.两者具体的语法如下: Sql代码 CAST(value as type); CONVERT(value, ...

  5. mysql字符串语法_MySQL语法模板 函数:字符串

    返回字符串的ASCII码ascii(str)返回字符串的二进制码bin(n)字符串的位数bit_length(str)字符串的字符数char(n,... [using charset])字符串的字符数 ...

  6. MySQL字符串函数

    字符串大写和小写转换 MySQL 字符串大写和小写转化函数有两对: lower(), uppper() 和 lcase(), ucase() mysql> select lower('DDD') ...

  7. [Mysql] SUBSTRING函数 | SUBSTRING_INDEX函数

    SUBSTRING函数 SUBSTRING函数是文本处理函数,可以截取字符串 格式: SUBSTRING(s, start, length) 从字符串s的start位置截取长度为length的子字符串 ...

  8. R语言提取字符串的一部分substring函数

    语法 这个函数提取字符串的一部分. substring()函数的基本语法是: substring(x,first,last) x - 是字符向量输入. first - 是第一个字符要被提取的位置. l ...

  9. MySQL字符串函数substring:字符串截取

    MySQL 字符串截取函数:left(), right(), substring(), substring_index().还有 mid(), substr().其中,mid(), substr() ...

最新文章

  1. adb server version(31) doesnt match this client(41)
  2. es中发现结点的角色
  3. windows下设置socket的connect超时
  4. flyway版本号_Flyway版本化管理数据库脚本
  5. php获取外部URL,使用PHP从外部API / URL获取信息
  6. mysql待办事项表名_Activiti中彻底解决待办事项列表查询复杂、API不友好的设计方案...
  7. tree命令的使用(过滤文件夹)
  8. 结合swiper使用图片懒加载
  9. 关于短信猫死机的问题程序要如何解决
  10. 根据excel模板导出多sheet且生成条形码或二维码插入excel指定位置中
  11. ECN Trade:最强飓风来袭,总统大选间断
  12. datastage错误之Consumed more than 100,000 bytes looking for record delimiter; aborting
  13. 老司机带你从源码开始撸Spring生命周期!!!
  14. 程序员最重要的核心竞争力是什么?
  15. 使用getsockopt函数判断TCP/IP异常
  16. Java程序员职业发展规划和方向
  17. 什么是“面向对象”程序设计-以Python为例
  18. 推荐两款Linux服务器连接的好工具
  19. Android简易音乐重构MVVM Java版-新增推荐菜单及侧边栏展示(十二)
  20. xgboost调参大法

热门文章

  1. Unity3d--实现第三人称视角(相机跟随)
  2. python制作我的世界_python的pygame制作的2D我的世界
  3. 推荐5个有趣又实用的机器学习项目,AI初学者也能玩起来!
  4. JS对象中的属性类型、属性定义和属性读取
  5. next主题侧边目录点击失效无法正常跳转
  6. 什么是十二时辰养生法
  7. python手工打码_利用打码兔和超人打码自封装的打码类分享
  8. linux 视频剪辑 剪辑人声,我这边有一个4分钟的剪辑视频,想把里边的人声给清除,背景音乐给留住...
  9. python是高级程序语言_高级语言程序设计(Python)_中国大学MOOC(慕课)
  10. openwrt的luci应用ipk包开发(一)