Mysql 字符串截取函数 SUBSTRING 的用法说明 Mysql字符串截取函数SUBSTRING的用法说明 作者: 字体: [ 增加

减小 ]

类型:转载 时间: 2011-06-24

我要评论 今天建视图时,用到了 MySQL 中的字符串截取,很是方便。 感觉上 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 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

已使用 Microsoft OneNote 2016 创建。