ySQL字符串函数substring:字符串截取 +判断是否包含某个字符的方法
一>MySQL字符串函数substring:字符串截取
MySQL 字符串截取函数:left(), right(), substring(), substring_index()。还有 mid(), substr()。其中,mid(), substr() 等价于 substring() 函数,substring() 的功能非常强大和灵活。
- 字符串截取: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);
- 字符串截取: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 不能取负值。
- 字符串截取: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:字符串截取 +判断是否包含某个字符的方法相关推荐
- mysql判断是否包含某个字符的方法
mysql判断是否包含某个字符的方法 用locate 是最快的,like 最慢.position一般 实战例子: select * from historydata where locate('0', ...
- mysql 是否包括字符_mysql判断是否包含某个字符的方法
mysql判断是否包含某个字符的方法 用locate 是最快的,like 最慢.position一般 实战例子: select * from historydata where locate('0', ...
- ySQL字符串函数:字符串截取
justdo2008 { "@context": "https://zhanzhang.baidu.com/contexts/cambrian.jsonld", ...
- 【Kotlin】字符串操作 ① ( 截取字符串函数 substring | 拆分字符串函数 split | 解构语法特性 )
文章目录 一.截取字符串函数 substring 二.拆分字符串函数 split 一.截取字符串函数 substring Kotlin 中提供了 截取字符串函数 substring , 可接收 Int ...
- java 字符串函数_Java字符串函数– 25+必须知道方法
java 字符串函数 Java字符串函数 (Java String Functions) Java String class has a lot of functions to manipulate ...
- 判断字符串不包含某个字符php,java判断字符串是否包含某个字符的方法
java判断字符串是否包含某个字符的方法: 一.contains方法 1:描述 java.lang.String.contains() 方法返回true,当且仅当此字符串包含指定的char值序列 2: ...
- 分割成数组php字符串函数,PHP 分割字符串函数把字符串分割成数组示例
这篇文章主要为大家详细介绍了PHP 分割字符串函数把字符串分割成数组示例,具有一定的参考价值,可以用来参考一下. 对PHP分割字符串函数把字符串分割成数组感兴趣的小伙伴,下面一起跟随512笔记的小编两 ...
- 题目 给定一个字符串所表示的括号序列,包含以下字符: '(', ')', '{', '}', '[' and ']', 判定是否是有效的括号序列。 样例 括号必须依照 ()顺序表示, ()[]
题目 给定一个字符串所表示的括号序列,包含以下字符: '(', ')', '{', '}', '[' and ']', 判定是否是有效的括号序列. 样例 括号必须依照 "()"顺序 ...
- MySQL字符串函数substring:字符串截取
MySQL 字符串截取函数:left(), right(), substring(), substring_index().还有 mid(), substr().其中,mid(), substr() ...
最新文章
- 某程序员毕业进UC,被阿里收购!跳去优酷土豆,又被阿里收购!再跳去饿了么,还被阿里收购!难道阿里想收购的是他?...
- 【玩转 Angular】1. Angular-CLI 安装与使用
- 导向滤波python_导向滤波(Guided Filter)简要介绍
- spring aop 如何切面到mvc 的controller--转载
- [收藏]C#实现超酷的图像效果(附源码)
- bucket sort count sort
- python中excel制作成绩报表_python制作简单excel统计报表2之操作excel的模块openpyxl简单用法...
- 原生JS字符串操作方法汇总
- float、定位、inline-block、兼容性需注意的特性总结
- SpringBoot加载静态资源
- ros自定义service消息.srv文件中增加自定义.msg消息
- android Volley解析之自定义CookieObjectRequest
- mac安装mysql devel_Mac安装Mysql
- 嵌入式c语言教程 题库 百度云,嵌入式c语言视频教程尚观主讲视频教程
- 用ImDisk在Windows 10中创建内存虚拟盘
- 使用VBSCRIPT安装字体
- 查找、下载芯片手册推荐网址
- Windows电脑系统上不错的五款优化软件
- 资料分析-第一章-统计术语
- windows 7系统中单独添加北京时区办法