MySQL字符串是怎么截取substring函数的?

感受MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,因此在这里作一个记录,但愿对你们有用。 php


 

函数: 

一、从左开始截取字符串 mysql

left(str, length) sql

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

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

二、从右开始截取字符串 学习

right(str, length) 测试

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

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

三、截取字符串 视频

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 则是从后倒数位数,到字符串结束或截取的长度) 

四、按关键字截取字符串 

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为一、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++学习企鹅圈子】,分享(源码、项目实战视频、项目笔记,基础入门教程)

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

编程学习书籍:


 

编程学习视频:

相关文章
相关标签/搜索