《MYSQL数据库Mysql字符串截取函数SUBSTRING的用法说明》要点:
本文介绍了MYSQL数据库Mysql字符串截取函数SUBSTRING的用法说明,希望对您有用。如果有疑问,可以联系我们。
函数简介:MYSQL学习
SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)MYSQL学习
不带有len 参数的格式从字符串str返回一个子字符串,起始于位置 pos.带有len参数的格式从字符串str返回一个长度同len字符相同的子字符串,起始于位置 pos. 使用 FROM的格式为标准 SQL 语法.也可能对pos使用一个负值.假若这样,则子字符串的位置起始于字符串结尾的pos 字符,而不是字符串的开头位置.在以下格式的函数中可以对pos 使用一个负值.MYSQL学习
详情请查阅手册.MYSQL学习
实例:
表1:user
MYSQL学习
表2:jl
MYSQL学习
期望效果:通过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的记录.MYSQL学习
那么怎么办呢?如果我们能够分别得到1,2中的1和2就行了.好在mysql也提供了字符串截取函数SUBSTRING.MYSQL学习
sql句法如下:
SELECT jl. *
FROM jl
WHERE jl.id = (
SELECT SUBSTRING( (MYSQL学习
SELECT user.jlid
FROM user
WHERE user.id =1
), 1, 1 ) )
OR jl.id = (MYSQL学习
SELECT SUBSTRING( (MYSQL学习
SELECT user.jlid
FROM user
WHERE user.id =1
), 3, 1 )
)
LIMIT 0 , 30MYSQL学习
简单解释一下:MYSQL学习
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 ) )
这条语句得到2MYSQL学习
1和2都得到了再通过主查询的where来查询,要注意我们需要查询id=1和id=2的记录,所以用到了OR,怎么样,是不是有点麻烦,MYSQL学习
您的第一直觉是不是要用2条sql语句,中间再配合php的explode函数来查询呢?这样想是正常的,但是这两者之间谁的效率高,站长并没有测试,希望有心的你,可以协助哦!MYSQL学习
《MYSQL数据库Mysql字符串截取函数SUBSTRING的用法说明》是否对您有启发,欢迎查看更多与《MYSQL数据库Mysql字符串截取函数SUBSTRING的用法说明》相关教程,学精学透。维易PHP学院为您提供精彩教程。