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

来源:脚本之家  责任编辑:小易  

substr(列名,值1,值2)获取列名值1和值2之间的数,例如select sunstr(name,2,4)from student where name='lilei'结果就是ileicharindex(值1,值2)返回值1在值2中的其实位置charindex('sql','microsoft.sql.server')结果返回11www.zgxue.com防采集请勿采集本网。

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

函数:

1、从左开始截取字符串

先把自动事务提交关掉,或者做好备份工作. SET AUTOCOMMIT=0;删除最后5个字符: UPDATE NEWS SET NEWSTEXT=substring(NEWSTEXT,1,length(NEWSTEXT)-5) WHERE ID BETWEEN 100 AND 200 AND length

left(str, length)

mysql 中有截取字符串的 但是不建议使用 mysql 进行截取操作效率很低 建议使用程序进行截取 如果比较 执着 下面的sql 可以截取字符 select left(content,200)as abstract from my_content_t 从左开始200个

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

select REVERSE(right(REVERSE(filename),length(filename)-LEAST if(Locate('0',REVERSE(filename))>0,Locate('0',REVERSE(filename)),999), if(Locate('1',REVERSE(filename))>0,Locate('1',

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

先判断的位置 position('_'in column_name) 再截取字符串就可以了 substr(column_name,1,position('_' in column_name))

2、从右开始截取字符串

要视情况而定,不同的要求有不同的截取办法。可分为从左往右截取,从右往左截取,从第几位截取,关键字截取。步骤如下。具体步骤如下: 从左开始截取字符串 left(str,length) 说明:left(被截取

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

有一些区别,使用T-SQL语句SQL SEVER。点击看详细,但差别不大,在MYSQL SQL SEVER报表基本上都可以使用,比如插入语句需要细微的变化。SQL SERVER顶部内不能在MYSQL,MYSQL限制使用来代替。点击看详细具体的你可以看一下说明书内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • mysql replace函数替换字符串语句的用法
  • mysql获取字符串长度函数(char_length)
  • mysql计算时间差函数
  • 详解mysql中concat函数的用法(连接字符串)
  • mysql中日期和时间戳互相转换的函数和方法
  • mysql日期函数与日期转换格式化函数大全
  • mysql常用函数汇总(分享)
  • mysql字符串处理函数详细介绍、总结
  • mysql存储过程与函数详解
  • mysql的存储过程和函数简单写法
  • mysql流程函数常见用法实例分析
  • 浅析mysql显式类型转换
  • mysql dml语句整理汇总
  • mysql5.7完全卸载步骤详解
  • mysql中数据类型的验证
  • 详解mysql索引原理以及优化
  • mysql 5.7双主同步部分表的实现过程详解
  • mysql从执行.sql文件时处理\n换行的问题
  • centos7.3下mysql5.7.18安装并修改初始密码的方法
  • 详细介绍基于mysql的搜索引擎mysql-fullltext
  • mac os10.12安装mysql5.7.18教程
  • MYSQL中使用sql函数怎样截取字符串
  • MYSQL中使用sql函数怎样截取字符串
  • MySQL截取字符串函数的几种方法
  • mysql怎么截取字段的字符串
  • 如何用MYSQL函数删除字符串最后几个字符
  • 请教,哪位大侠知道mysql 中截取字符串的function怎么写?(比如字符串根据逗号截取),谢谢了
  • mysql 截取字符串中的数字
  • 各位大神,MySQL截取字符串到某一制定位置,语句怎么写?
  • mysql的查询中怎么截取字符串
  • 如何利用MySQL数据库中的字符串函数拼接截取
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页mysqlmysql replace函数替换字符串语句的用法mysql获取字符串长度函数(char_length)mysql计算时间差函数详解mysql中concat函数的用法(连接字符串)mysql中日期和时间戳互相转换的函数和方法mysql日期函数与日期转换格式化函数大全mysql常用函数汇总(分享)mysql字符串处理函数详细介绍、总结mysql存储过程与函数详解mysql的存储过程和函数简单写法mysql流程函数常见用法实例分析浅析mysql显式类型转换mysql dml语句整理汇总mysql5.7完全卸载步骤详解mysql中数据类型的验证详解mysql索引原理以及优化mysql 5.7双主同步部分表的实现过程详解mysql从执行.sql文件时处理\n换行的问题centos7.3下mysql5.7.18安装并修改初始密码的方法详细介绍基于mysql的搜索引擎mysql-fullltextmac os10.12安装mysql5.7.18教程mysql安装图解 mysql图文安装教程windows下mysql5.6版本安装及配置can""t connect to mysql servermysql字符串截取函数substring的mysql创建用户与授权方法mysql提示:the server quit withmysql日期数据类型、时间类型使用mysql——修改root密码的4种方法mysql update语句的用法详解mysql 的case when 语句使用说明解决当mysql数据库遇到syn flooding问题windows下傻瓜式安装mysql5.7mysql 5.6.14 win32位免安装解压缩版配置windows10下mysql 5.7.17 安装配置方法图mysql 的存储引擎,myisam和innodb的区别mysql 5.7.9 服务无法启动-“net helpmsgmysql清除log-bin日志的方法mysql数据库服务器逐渐变慢分析与解决方法mysql5.7忘记root密码及mysql5.7修改rootmysql中表单输入数据出现中文乱码的解决方
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved