一>MySQL字符串函数substring:字符串截取
MySQL 字符串截取函数:left(), right(), substring(), substring_index()。还有 mid(), substr()。其中,mid(), substr() 等价于 substring() 函数,substring() 的功能非常强大和灵活。

  1. 字符串截取:left(str, length)

mysql> select left(‘example.com’, 3);
±------------------------+
| left(‘example.com’, 3) |
±------------------------+
| exa |
±------------------------+
2. 字符串截取:right(str, length)

mysql> select right(‘example.com’, 3);
±-------------------------+
| right(‘example.com’, 3) |
±-------------------------+
| com |
±-------------------------+

实例:

#查询某个字段后两位字符
select right(last3, 2) as last2 from historydata limit 10;
#从应该字段取后两位字符更新到另外一个字段
update historydata set last2=right(last3, 2);

  1. 字符串截取:substring(str, pos); substring(str, pos, len)

3.1 从字符串的第 4 个字符位置开始取,直到结束。

mysql> select substring(‘example.com’, 4);
±-----------------------------+
| substring(‘example.com’, 4) |
±-----------------------------+
| mple.com |
±-----------------------------+
3.2 从字符串的第 4 个字符位置开始取,只取 2 个字符。

mysql> select substring(‘example.com’, 4, 2);
±--------------------------------+
| substring(‘example.com’, 4, 2) |
±--------------------------------+
| mp |
±--------------------------------+
3.3 从字符串的第 4 个字符位置(倒数)开始取,直到结束。

mysql> select substring(‘example.com’, -4);
±------------------------------+
| substring(‘example.com’, -4) |
±------------------------------+
| .com |
±------------------------------+
3.4 从字符串的第 4 个字符位置(倒数)开始取,只取 2 个字符。

mysql> select substring(‘example.com’, -4, 2);
±---------------------------------+
| substring(‘example.com’, -4, 2) |
±---------------------------------+
| .c |
±---------------------------------+
我们注意到在函数 substring(str,pos, len)中, pos 可以是负值,但 len 不能取负值。

  1. 字符串截取:substring_index(str,delim,count)

4.1 截取第二个 ‘.’ 之前的所有字符。

mysql> select substring_index(‘www.example.com’, ‘.’, 2);
±-----------------------------------------------+
| substring_index(‘www.example.com’, ‘.’, 2) |
±-----------------------------------------------+
| www.example |
±-----------------------------------------------+
4.2 截取第二个 ‘.’ (倒数)之后的所有字符。

mysql> select substring_index(‘www.example.com’, ‘.’, -2);
±------------------------------------------------+
| substring_index(‘www.example.com’, ‘.’, -2) |
±------------------------------------------------+
| example.com |
±------------------------------------------------+
4.3 如果在字符串中找不到 delim 参数指定的值,就返回整个字符串

mysql> select substring_index(‘www.example.com’, ‘.coc’, 1);
±--------------------------------------------------+
| substring_index(‘www.example.com’, ‘.coc’, 1) |
±--------------------------------------------------+
| www.example.com |
±--------------------------------------------------+

二>mysql判断是否包含某个字符的方法

用locate 是最快的,like 最慢。position一般
实战例子:
select * from historydata
where locate(‘0’,opennum) and locate(‘1’,opennum)
order by number desc limit 10;

方法一:locate(字符,字段名)
使用locate(字符,字段名)函数,如果包含,返回>0的数,否则返回0 ,

它的别名是 position in
select * from 表名 where locate(字符,字段)
select * from 表名 where position(字符 in 字段);

例子:判断site表中的url是否包含’http://'子串,如果不包含则拼接在url字符串开头
update site set url =concat(‘http://’,url) where locate(‘http://’,url)=0

注意mysql中字符串的拼接不能使用加号+,用concat函数

方法二:like
SELECT * FROM 表名 WHERE 字段名 like “%字符%”;

方法三:find_in_set()
利用mysql 字符串函数 find_in_set();

SELECT * FROM users WHERE find_in_set(‘字符’, 字段名);
mysql有很多字符串函数 find_in_set(str1,str2)函数是返回str2中str1所在的位置索引,str2必须以","分割开。
注:当str2为NO1:“3,6,13,24,33,36”,NO2:“13,33,36,39”时,判断两个数据中str2字段是否包含‘3’

mysql > SELECT find_in_set()(‘3’,‘3,6,13,24,33,36’) as test;
-> 1
mysql > SELECT find_in_set()(‘3’,‘13,33,36,39’) as test;
-> 0

方法四:INSTR(字段,字符)
select * from 表名 where INSTR(字段,字符)

1》用于获得字符串去掉分隔符的实际长长度与分隔的个数:
例如: ‘1,2,3,4’,去掉分隔符为‘1234’,
select cgid,LENGTH(cgid),LENGTH(REPLACE(cgid,‘,’,‘’)) from cgout
2》借助一个表取字段:
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(‘7654,7698,7782,7788’,‘,’,help_topic_id+1),‘,’,-1) AS num
FROM mysql.help_topic
WHERE help_topic_id < LENGTH(‘7654,7698,7782,7788’)-LENGTH(REPLACE(‘7654,7698,7782,7788’,‘,’,‘’))
3》假设前端页面传过来选中的一串含分隔符的id,数据库如何处理:
CREATE DEFINER=root@% PROCEDURE cgio(in fg int,in cgidt varchar(1000),out error int)
BEGIN
SET error=0;
if ifnull(fg,0)=1 then
truncate table cgout;
insert into cgout(cgid) select id from cg where FIND_IN_SET(id,cgidt); 用到find_in_set function;
end if;
end

ySQL字符串函数substring:字符串截取 +判断是否包含某个字符的方法相关推荐

  1. mysql判断是否包含某个字符的方法

    mysql判断是否包含某个字符的方法 用locate 是最快的,like 最慢.position一般 实战例子: select * from historydata where locate('0', ...

  2. mysql 是否包括字符_mysql判断是否包含某个字符的方法

    mysql判断是否包含某个字符的方法 用locate 是最快的,like 最慢.position一般 实战例子: select * from historydata where locate('0', ...

  3. ySQL字符串函数:字符串截取

    justdo2008 { "@context": "https://zhanzhang.baidu.com/contexts/cambrian.jsonld", ...

  4. 【Kotlin】字符串操作 ① ( 截取字符串函数 substring | 拆分字符串函数 split | 解构语法特性 )

    文章目录 一.截取字符串函数 substring 二.拆分字符串函数 split 一.截取字符串函数 substring Kotlin 中提供了 截取字符串函数 substring , 可接收 Int ...

  5. java 字符串函数_Java字符串函数– 25+必须知道方法

    java 字符串函数 Java字符串函数 (Java String Functions) Java String class has a lot of functions to manipulate ...

  6. 判断字符串不包含某个字符php,java判断字符串是否包含某个字符的方法

    java判断字符串是否包含某个字符的方法: 一.contains方法 1:描述 java.lang.String.contains() 方法返回true,当且仅当此字符串包含指定的char值序列 2: ...

  7. 分割成数组php字符串函数,PHP 分割字符串函数把字符串分割成数组示例

    这篇文章主要为大家详细介绍了PHP 分割字符串函数把字符串分割成数组示例,具有一定的参考价值,可以用来参考一下. 对PHP分割字符串函数把字符串分割成数组感兴趣的小伙伴,下面一起跟随512笔记的小编两 ...

  8. 题目 给定一个字符串所表示的括号序列,包含以下字符: '(', ')', '{', '}', '[' and ']', 判定是否是有效的括号序列。 样例 括号必须依照 ()顺序表示, ()[]

    题目 给定一个字符串所表示的括号序列,包含以下字符: '(', ')', '{', '}', '[' and ']', 判定是否是有效的括号序列. 样例 括号必须依照 "()"顺序 ...

  9. MySQL字符串函数substring:字符串截取

    MySQL 字符串截取函数:left(), right(), substring(), substring_index().还有 mid(), substr().其中,mid(), substr() ...

最新文章

  1. 某程序员毕业进UC,被阿里收购!跳去优酷土豆,又被阿里收购!再跳去饿了么,还被阿里收购!难道阿里想收购的是他?...
  2. 【玩转 Angular】1. Angular-CLI 安装与使用
  3. 导向滤波python_导向滤波(Guided Filter)简要介绍
  4. spring aop 如何切面到mvc 的controller--转载
  5. [收藏]C#实现超酷的图像效果(附源码)
  6. bucket sort count sort
  7. python中excel制作成绩报表_python制作简单excel统计报表2之操作excel的模块openpyxl简单用法...
  8. 原生JS字符串操作方法汇总
  9. float、定位、inline-block、兼容性需注意的特性总结
  10. SpringBoot加载静态资源
  11. ros自定义service消息.srv文件中增加自定义.msg消息
  12. android Volley解析之自定义CookieObjectRequest
  13. mac安装mysql devel_Mac安装Mysql
  14. 嵌入式c语言教程 题库 百度云,嵌入式c语言视频教程尚观主讲视频教程
  15. 用ImDisk在Windows 10中创建内存虚拟盘
  16. 使用VBSCRIPT安装字体
  17. 查找、下载芯片手册推荐网址
  18. Windows电脑系统上不错的五款优化软件
  19. 资料分析-第一章-统计术语
  20. windows 7系统中单独添加北京时区办法

热门文章

  1. Unity中设置屏幕常亮
  2. 数组 删除数组中的重复项
  3. 苏格拉底与麦穗的故事
  4. Flash Player渲染模型(显示列表)
  5. gitLab汉化出错问题
  6. Java 自动装箱拆箱原理及避坑
  7. 有了别人的发动机,能不能仿造出来?
  8. 美国莱斯大学副教授胡侠|“没有人会为无聊的事情奋斗一辈子”
  9. 2022阿里云峰会·广东
  10. Windows11为什么要关闭vbs?