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

感觉上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.phpstudy.net","。",2) as abstract from my_content_t

结果:blog.phpstudy

(注:如果关键字出现的次数是负数 如-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函数来查询呢?这样想是正常的,但是这两者之间谁的效率高,站长并没有测试,希望有心的你,可以帮忙哦!相关阅读:

理解(X)HTML的文档结构

使用用户自定义的logo来替换iNotes Web Access原有的logo

aspupload 3.0 下载与使用集锦

如何动态的生成Asp.net前端的显示

在MySQL数据库中执行SQL语句时的几个注意点

CSS教程:伪清除浮动

CSS实用教程(一)

Linux与Unix比较 Ftp/Telnet服务配置

PHP 增加了对 .ZIP 文件的读取功能

SQL语句 一个简单的字符串分割函数

javascript 表单日期选择效果

XMLHTTPRequest的属性和方法简介

保障Windows Server 2003域控制器的安全性

jquery.validate使用攻略 第一部

php mysql字符串截取比较读取_MySQL_Mysql字符串截取函数SUBSTRING的用法说明,感觉上MySQL的字符串函数截取 - phpStudy...相关推荐

  1. mysql截取字符串最后两位_Mysql字符串截取函数SUBSTRING的用法说明

    感觉上MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用. 函数: 1.从左开始截取字符串 left(str, length) 说明:le ...

  2. mysql截取字符串后缀_Mysql字符串截取函数SUBSTRING的用法说明

    今天建视图时,用到了MySQL中的字符串截取,很是方便 感觉上MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用. 函数: 1.从左开始截 ...

  3. mysql 从第几个字符串开始截取_Mysql字符串截取函数SUBSTRING的用法说明

    感觉上MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用. 函数: 1.从左开始截取字符串 left(str, length) 说明:le ...

  4. mysql截取点前面两位的字符串,Mysql字符串截取函数SUBSTRING的用法说明

    搜索热词 感觉上MysqL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用. 函数: 1.从左开始截取字符串 left(str,length) 说 ...

  5. mysql 从第几位开始截取_Mysql字符串截取函数SUBSTRING的用法说明

    今天建视图时,用到了MySQL中的字符串截取,很是方便. 感觉上MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用. 函数: 1.从左开始 ...

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

    2019独角兽企业重金招聘Python工程师标准>>> 感觉上MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用.  函 ...

  7. mysql 从后往前截取指定个数字符串_Mysql字符串截取函数SUBSTRING的用法说明

    函数: 1.从左开始截取字符串 left(str, length) 说明:left(被截取字段,截取长度) 例:select left(content,200) as abstract from my ...

  8. mysql substring用法_Mysql字符串截取函数SUBSTRING的用法说明

    函数: 1.从左开始截取字符串 left(str, length) 说明:left(被截取字段,截取长度) 例:select left(content,200) as abstract from my ...

  9. java中字符串函数_JAVA中字符串函数subString的用法小结

    string str;str=str.substring(int beginindex);截取掉str从首字母起长度为beginindex的字符串,将剩余字符串赋值给str: str=str.subs ...

最新文章

  1. 语句中如何结束本循环进入下一循环_第33 p,for遍历,循环取值最方便
  2. vnc用户名 查看linux_linux 查看vnc服务器
  3. 扣押游戏android,恐怖探索游戏「扣押(DISTRAINT)」
  4. struct和typedef struct的区别(转)
  5. php 脏数据,脏数据和时间戳,还有数据一致性校验
  6. (*长期更新)软考网络工程师学习笔记——Section 9 应用层
  7. mysql or会用到索引吗_mysql or条件可以使用索引而避免全表
  8. vue中实现美团双级联动菜单
  9. 孩子学python用什么教材比较好-python大学里用哪本教材比较好?
  10. Windows 10修改环境变量方法
  11. 【Linux】tmpfs简介及增加方式
  12. QT造类器(操作简单)
  13. 真人发音计算机在线用,文字转语音真人发声在线怎么转换?这种操作最简单
  14. 我的世界 服务器文件ess,《我的世界》ess指令大全 ess指令作用
  15. 安装PS 无法选择路径
  16. Scrapy vs BeautifulSoup
  17. 学习笔记_曲根词汇_词根词缀_联想记忆_第61_71_74节课
  18. 金融风控——Python建模
  19. 读取位置 0xdddddddd 时发生访问冲突
  20. android车载支持格式,DIY自己的安卓车载中控(支持原车协议)

热门文章

  1. react 使用dom-to-image 将html转为图片并保存
  2. 获取windows系统ip、计算机名、当前用户名
  3. OSI七层网络模型介绍
  4. SSM 项目 --------- 小米商城后台管理系统
  5. 提取html string,c#从html中提取文本
  6. 中文参考文献如何导出+如何插入参考文献
  7. 欧拉定理学习20161004
  8. Appium: Windows系统桌面应用自动化测试(一)
  9. pdf文件过大如何缩小上传
  10. 基于WeMos D1+esp8266的智能垃圾桶和智能家居