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

时间:2024-01-24 14:53:51 

感觉上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
Mysql字符串截取函数SUBSTRING的用法说明

表2:jl
Mysql字符串截取函数SUBSTRING的用法说明

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

标签:Mysql,SUBSTRING,字符串截取
0
投稿

猜你喜欢

  • MySQL时间设置注意事项的深入总结

    2024-01-16 04:39:52
  • MySQL Workbench安装及使用详解

    2024-01-27 10:52:15
  • Python的10道简单测试题(含答案)

    2021-12-28 03:57:24
  • Node Express用法详解【安装、使用、路由、中间件、模板引擎等】

    2024-05-11 10:49:24
  • innerHTML,outerHTML,innerText,outerText用法

    2008-02-15 12:22:00
  • python列表倒序的几种方法(切片、reverse()、reversed())

    2022-01-28 02:46:52
  • EasyASP v1.5发布(包含数据库操作类,原clsDbCtrl.asp)第1/2页

    2011-04-08 10:40:00
  • mysql 5.7.16 免安装版安装配置方法图文教程

    2024-01-15 18:42:17
  • SQL 存储过程基础语法之一

    2024-01-26 19:58:05
  • Postman返回中文乱码的解决方案

    2022-03-16 15:03:02
  • python误差棒图errorbar()函数实例解析

    2023-12-14 22:39:49
  • SQLSERVER 本地查询更新操作远程数据库的代码

    2024-01-21 05:16:47
  • sql server 带列名导出至excel

    2008-11-25 11:07:00
  • Sql Server 无日志文件附加

    2010-05-30 11:23:00
  • OpenCV立体图像深度图Depth Map基础

    2021-09-23 22:12:59
  • 分享vim python缩进等一些配置

    2022-09-28 00:12:55
  • Python使用matplotlib的pie函数绘制饼状图功能示例

    2022-09-27 23:58:58
  • 交互设计实用指南系列(12)—避免出错

    2010-04-12 13:02:00
  • python中asyncio异步编程学习

    2022-10-20 06:19:37
  • python调用staf自动化框架的方法

    2021-11-03 17:47:43
  • asp之家 网络编程 m.aspxhome.com