MySQL常见函数的讲解

函数:将某些功能封装到一起,对外提供到一个接口(函数名),通过函数调用的方式可以重复的执行函数里的功能,从而提高我们的代码的复用性。

MySql里自带了很多已经封装好了的函数,可以帮我们实现很多功能

MySql里调用函数和java一样用函数名(),完整的写法:

**select 函数名(实参)**from 表名

字符函数:

1、length(str):获取参数的字节数

select length('abcd'); // 返回值:4

select length('小白abc'); // 返回值:与字符编码类型有关

show variables like '%char%'; //查看数据可客服端字符集编码

GBK:一个汉字占两个字节;UTF-8:一个汉字是占三个字节.

2、concat(str1,str2,...):连接字符串

select concat(last_name,'--',first_name) as 姓名 from employees;

3、upper(str):小写字母变大写; lower(str):大写字母变小写;

select upper('zhonghao');

select lower('XIAOBEI');

案例:查询员工姓和名,把姓大写,名小写,并用&连接起来显示。

SELECT CONCAT(LOWER(first_name),"&",UPPER(last_name)) `name` FROM employees;

4、substr 和 substring

案例:截取字符串,从第4个字符(包含)开始到最后

select substr('目标字符串',4) as out_put; //注意:Mysql中索引值是从1开始的,和java不同,java索引是从0开始的.

案例:截取字符串,从第二个开始接到第三个

select substr('目标字符串',2,1) as out_put; //注意:第一个数字是开始截取的索引值,第二个数数截取的长度

5、instr('源字符串','子字符串'):作用返回子字符串子源字符串里的起始索引.

select instr('目标字符串','字符串'); //返回结果3, 如果找不到返回0

6、trim(' 有空格的字符串 '):作用是去掉字符串前后的空格,中间空格去不掉

select lenght(trim(' a s '));

扩展用法:去掉前后两端的其他字符:select trim('a' from 'aaaaa字符aaaaa去掉aaaaa');

7、lpad('目标字符串',10,'填充字符'); 将填充字符填充到目标字符的左边,补足10个

select lpad('哈哈哈',10,'*'); // 如果中间的数字比目标字符长度小,就只截取左边的数字长度字符串.

8、rpad:与lpad只是填充方向相反,其他一样;

9、replace('目标字符串','被替换子串','用于替换的新串')替换

select replace('目标字符串','字符','哈哈');

相关推荐
zhoutongsheng1 小时前
C#怎么实现Swagger文档 C#如何在ASP.NET Core中集成Swagger自动生成API文档【框架】
jvm·数据库·python
WinterKay1 小时前
【开源】我写了一个轻量级本地数据库浏览工具,支持 MySQL/Redis 只读查询
数据库·mysql·开源
zxrhhm2 小时前
Oracle 索引完整指南
数据库·oracle
程序猿乐锅3 小时前
【Tilas|第三篇】多表SQL语句
数据库·经验分享·笔记·学习·mysql
Navicat中国4 小时前
使用 Navicat 导入向导导入 Excel 数据时,系统提示导入成功,表中也能看到数据,但行数统计显示为 0,这是什么原因?
数据库·excel·导入
gmaajt4 小时前
Golang怎么做国际化多语言_Golang i18n教程【核心】
jvm·数据库·python
折哥的程序人生 · 物流技术专研4 小时前
从“卡死”到“秒过”:WMS销售数据跨库回填的极限优化之旅
数据库·机器学习·oracle
李可以量化4 小时前
DeepSeek 量化交易实战:用标准化提示词模板实现 AI 辅助交易决策
大数据·数据库·人工智能
maqr_1104 小时前
CSS如何利用Sass定义全局阴影方案_通过变量实现统一CSS风格
jvm·数据库·python
m0_613856294 小时前
uni-app怎么做类似于美团的商家评价星级 uni-app五星评分组件制作【实战】
jvm·数据库·python