Mysql字符串截取函数SUBSTRING的用法说明

函数:

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 substring_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

表2:jl

期望效果:通过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函数来查询呢?这样想是正常的,但是这两者之间谁的效率高,站长并没有测试,希望有心的你,可以帮忙哦!

 

http://www.jb51.net/article/27458.htm

http://www.jb51.net/article/39199.htm

转载于:https://www.cnblogs.com/linksky1018/p/mysql.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL中,可以使用SUBSTRING函数来截取字符串。SUBSTRING函数有两种用法: 1. 从左开始截取字符串:使用LEFT函数,语法为SELECT LEFT(str, len),其中str是被截取的字符串,len是截取的长度。例如,SELECT LEFT('TF-8220210412003-1', 10)将返回TF-8220210。\[3\] 2. 从右开始截取字符串:使用RIGHT函数,语法为SELECT RIGHT(str, len),其中str是被截取的字符串,len是截取的长度。例如,SELECT RIGHT('TF-8220210412003-1', 6)将返回2003-1。\[2\] 需要注意的是,截取的长度参数是可选的。如果不指定长度,SUBSTRING函数将从指定的位置开始截取到字符串的末尾。 希望这个回答对你有帮助! #### 引用[.reference_title] - *1* [Mysql截取字符串](https://blog.csdn.net/weixin_44446619/article/details/116000442)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [MySQL字符串截取:左截取、右截取、按关键字截取...](https://blog.csdn.net/weixin_44917045/article/details/120496464)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值