首页 > 数据库 >3.MySQL常用函数

3.MySQL常用函数

时间:2024-12-16 16:59:24浏览次数:9  
标签:返回 常用 函数 expr len 字符串 str MySQL date

常用命令

● alter add

alter table add <table_name> add <column_name> <data_type>
[约束类型] [first | after 已经存在的字段名]

● rename

alter table <旧表名> rename [to] <新表明>;

● mysqldump

mysqldump -uroot -hlocalhost -P3306 -p123456 dbname [table_name,[table_name]] > filename.sql

操作符优先等级

INTERVAL

BINARY COLLATE

!

  • (unary minus), ~ (unary bit inversion)

^

  • , / , DIV , % , MOD

-, +

<< , >>

&

|

= (comparsion) , <=>,>=,>,<=,<,<>,!=,is,like,regexp ,in

between ,case , when ,then, else

not

and ,&&

xor

or , ||

= (assignment) , :=

如果想改变优先级执行顺序,则可以使用括号

对比操作符的执行结果为True,false,null

interval() # 代表返回比第一个参数小的参数位置

least() # 代表返回最小的参数

greatest() # 返回最大的值

strcmp() # 对比两个字符串

逻辑操作符,返回1(true),0(false),null

and , &&

not , !

||, or

xor

分配操作符
name description
= assign a value (as part of a set statement,or as part of the set clause in an update statement),其他情况下皆认为是对比操作符
:= assign a value

流程控制函数
name description
case case operator
if() if/else construct
ifnull() null if /else construct
nullif() return null if expr1 = expr2

case语句的用法

case value
when [compare_value] then result
[when [compare_value] then result...] [else result]
end

if的用法

if(expr1,expr2,expr3) # 当expr1为1/true,则返回expr2,否则返回expr3

ifnull的用法

ifnull(expr1,expr2) # 当expr1为null时,返回expr2,否则返回expr1

nullif的用法

nullif(expr1,expr2) # 当expr1等于expr2时,则返回null,否则返回expr1

字符串函数

ascii(str) # 返回字符串中最左边字符的ascii码值,如果是空字符串,则返回0,如果是str是null则返回null

char(N ,...[using charset_name]) # 将括号中的N转化为ASCII对饮的字符,返回这些字符组成的自负床,其中null会被忽略

char_length(str) # 返回字符串的字符长度

concat(str1,str2,...) # 返回括号里所有自负串连接在一起,当其中有null时,则返回null

concat_ws(separator,str1,str2,...) # 返回以第一个参数为分隔符的连接后的一个字符串,当有参数为null时,则null被忽略

GROUP_CONCAT(DISTINCT expression
ORDER BY expression
SEPARATOR sep); # 将分组后的数据按照指定的字符将其进行

insert(str,pos,len,newstr) # 将字符串中从pos位置开始后的len个字符替换成为newstr

instr(str,substr) # 返回字符串中第一个出现substr字符串的位置,如果没有则返回0

left(str,len) # 返回str中从左边开始的len个长度的字符

length(str) # 返回str的字节byte字节长度

load_file(file_name) # 读取文件且返回文件内容为字符串

locate(substr,str) # 返回str中第一次出现substr字符串的位置,如果没有则返回null

locate(substr,str,pos) # 返回str字符串中从pos位置开始第一次出现substr字符串中的位置,如果没有则返回null

lpad(str,len,padstr) # 将str的左边补充为padstr,直到补充成len长度的字符串并返回,如果str的长度比len长,则返回str中最左边开始到len长度的字符

ltrim(str) # 将str左边的空白字符去掉并返回

repeat(str,count) # 将str重复count并组成字符串返回,如果count<1,则返回空串

replace(str,from_str,to_str) # 将所有str中的from_str替换为to_str

reverse(str) # 将str中的字符按照倒序组合并返回

right(str,len)

rpad(str,len,padstr) # 与lpad相反操作

rtrim(str)

space(n) # 返回n个长度的空格组成的空字符串

SUBSTR(str,pos), SUBSTR(str FROM pos), SUBSTR(str,pos,len), SUBSTR(str FROM pos FOR len)
SUBSTRING(str,pos), SUBSTRING(str FROM pos), SUBSTRING(str,pos,len), SUBSTRING(str FROM pos FOR len)

如果没有len参数,则返回从pos位置开始的str中的子字符串;如果有len参数,则从pos位置开始返回str中长度为len的子字符串;如果pos为负值,则代表pos从右边开始数

SUBSTRING_INDEX(str,delim,count) # 当count为正数,则返回delim出现在str字符串中第count次之前的子字符串,如果是负数,则从右边开始计算

拆分字符串 split,想法,将值按substring_index进行切分,由于参数限制,需要对substring_index的函数进行二次拆分,先正数,后负数即可得到中间值,此过程需要一个自增的字段值,需要通过mysql.help_topic这个表来进行帮助

SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(f.split_test, ',', help_topic_id + 1), ',', -1)
FROM (SELECT '2022-02,2022-03,2022-04,2022-05' as split_test ) as f
JOIN mysql.help_topic
ON help_topic_id < LENGTH(f.split_test) - LENGTH(REPLACE(f.split_test, ',' , '')) + 1

数字函数

abs(x) # 返回绝对值

CEILING(X)/CEIL(X) # 返回>=x最小整数

floor(x) # 返回<=x值的最大整数

MOD(N,M), N % M, N MOD M # 取余数操作,返回两者相除之后剩下的余数

RAND([N]) # 获取0到1之间的随机小数,比如当想获取7~12之间的随机整数是可以使用SELECT FLOOR(7 + (RAND() * 5))

ROUND(X), ROUND(X,D) # 四舍五入为D位个小数,当D参数不存在是,则默认为0

TRUNCATE(X,D) # 数字X只保留D位的小数,其余均舍弃

日期和时间函数

ADDDATE(date,INTERVAL expr unit), ADDDATE(expr,days) # 当expr为正数时则为增加时间,为负数时则为减少时间,Unit参数可以是任意时间单位

ADDTIME(expr1,expr2) # 将expr2的时间增加到expr1上

CONVERT_TZ(dt,from_tz,to_tz) # 将时间dt从from_tz这个时区转换成to_tz这个时区并返回

CURDATE(), CURRENT_DATE, CURRENT_DATE() # 返回以yyyy-mm-dd或者yyyymmdd格式的当前时间

CURTIME(),CURRENT_TIME,CURRENT_TIME() # 按照hh:mm:ss或者hhmmss格式返回当前时间

Now(), CURRENT_TIMESTAMP,CURRENT_TIMESTAMP() # 返回当前的日期和时间,格式为yyyy-mm-dd hh:mi:ss或者

DATE(expr) # 获取expr中的日期, SELECT DATE('2003-12-31 01:02:03'); 返回 '2003-12-31‘

DATEDIFF(expr1,expr2) # 返回expr1和expr2之间的天数差异,忽略时分秒

DATE_ADD(date,INTERVAL expr unit), DATE_SUB(date,INTERVAL expr unit) # 增加或者减少时间

DATE_FORMAT(date,format) # 将date日期时间转换成format格式

DAY(date), DAYOFMONTH(date) # 返回date中日期在当前月份中是第几天

DAYNAME(date) # 返回date时间是星期几

DAYOFWEEK(date) # 返回date时间是星期“几”

DAYOFYEAR(date) # 返回date是一年中的第几天,取值范围在1~366

EXTRACT(unit FROM date) # Unit单元和date_add/date_sub函数中的一样,是获取date日期的unit部分

FROM_UNIXTIME(unix_timestamp), FROM_UNIXTIME(unix_timestamp,format) # 根据给定的unixtime,返回yyyy-mm-ddhh:mi:ss或者yyyymmddhhmiss格式的具体时间,或者按照format返回时间

LAST_DAY(date) # 返回date日期所在月份的最后一天日期

SYSDATE() # 返回当前日期和时间,格式为yyyy-mm-ddhh:mi:ss或者yyyymmddhhmiss,和now()函数的区别在于now()返回的时间是语句执行的时间,而sysdate()返回的时间是该函数执行的时间

TIME(expr) # 返回expr日期时间中的时间部分

UNIX_TIMESTAMP(), UNIX_TIMESTAMP(date) # 如果没有date参数,则返回当前时间到1970-01-01 00:00:00之间的秒数,如果有date参数,则表示date到1970-01-01 00:00:00之间的秒数

STR_TO_DATE(STR,format) ,STR_TO_DATE()根据fmt格式字符串将str字符串转换为日期值

格式转换函数

Cast()和convert()两个函数都可以用来转换数据类型或者转换字符集
允许转换的数据类型包括:
•Binary[N]
•char[N]
•Date
•Datetime
•decimal[M,[D]]
•Time
•Signed [integer]
•Unsigned [integer]
SELECT CONVERT(_latin1'Müller' USING utf8);
SELECT CONVERT('test', CHAR CHARACTER SET utf8);
SELECT CAST('test' AS CHAR CHARACTER SET utf8);
select CAST('2000-01-01' AS DATE);
select CONVERT('2000-01-01', DATE);

聚合函数

AVG([DISTINCT] expr) # 计算expr的平均值,distinct关键词表示是否排除重复值

COUNT(expr) # 计算expr中的个数,如果没有匹配则返回0,注意NULL的区别

COUNT(DISTINCT expr,[expr...]) # 计算有多少个不重复的expr值,注意是计算非NULL的个数

MAX([DISTINCT] expr),MIN([DISTINCT] expr) # 返回expr中最大或者最小的值

SUM([DISTINCT] expr) # 返回expr的求和值

标签:返回,常用,函数,expr,len,字符串,str,MySQL,date
From: https://www.cnblogs.com/shuiyirar/p/18610580

相关文章

  • 4.mysql中的存储过程
    创建存储过程和函数CREATE [DEFINER={USER|CURRENT_USER}]#定义者是谁 PROCEDUREsp_name([proc_parameter[,...]]) [characteristic...]routine_body CREATE [DEFINER={USER|CURRENT_USER}] FUNCTIONsp_name([function_name[,...]]) [characteristic.......
  • 1.mysql部署文档
    部署方式1.docker上面部署●部署最新版本dockerpullmysql:latest#拉取最新版本的镜像文件dockerimages#查看已经安装的镜像文件dockerps-a#c运行mysql容器dockerrun-itd--namemysql-test-p3306:3306-eMYSQL_ROOT_PASSWORD=123456mysql参数说明-p......
  • 【Mysql优化】EXPLAIN 返回列详解:深入 SQL 查询优化的工具
    文章目录什么是EXPLAIN?使用方法`EXPLAIN`返回的各列详解1.`id`列示例:简单查询示例:嵌套查询2.`select_type`列示例:UNION查询3.`table`列示例:4.`partitions`列5.`type`列示例:全表扫描示例:索引查询6.`possible_keys`列7.`key`列8.`key_len`列9.`re......
  • 常用UI组件库
    https://www.iviewui.com1.**ElementPlus**-官方网站:https://element-plus.org/-ElementPlus是由ElementUI升级而来的一个基于Vue3的桌面端组件库,拥有完整的组件体系,适合中后台产品的开发。2.**AntDesignofVue**-官方网站:https://2x.antdv.com/do......
  • jvm常用命令
    ​ jmap-dump:format=b,file=将堆内存进行文件导出,但是jvm为了保留数据一致性,可能会卡顿,并且导出前会进行一次fullGC,实验:6G的最大堆应用导出30s左右查看gc日志jstat-gcpid查看堆存活对象jmap-histo:live[pid]使用:jmap-histo|less可得到如下包含对象序号、某个......
  • cordova-plugin-wechat实现微信登录授权,我本地打包可以拉起微信并进入授权成功回调函
    经过打包了很多次的测试,发现问题出在了cordova版本上,之前因为需要降低node.js的版本,重新安装了cordova为最新版本12.0.0,在这个环境下,我打包出来的签名包可以正常拉起微信并进入授权成功回调函数。之前开发配置的cordova版本是11.1.0,这个版本打出来的包就是可以拉起微信,但进入去授......
  • MySQL锁机制学习随笔
    MySQL锁机制学习随笔锁机制是什么?锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除了传统的计算资源(如CPU、RAM、I/O等)的争用以外,数据也是一种供需要用户共享的资源。如何保证数据并发访问的一致性、有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据......
  • Wechat.auth成功回调函数执行了,但是没有拉起微信,点击微信分享又是正常的
    2024/12/11我又遇到一个奇葩现象,微信没有拉起,但是微信授权成功的回调函数却执行了,目前原因还在排查中......用另一个微信测试又可以,看来是微信的问题,代码是ok的,后面我就没管了。2024/12/16刚ai问了一下,会不会是这个问题:今天继续排查发现,微信授权了一次之后,之后就不需要再授......
  • 免费送源码:Java+springboot+MySQL springboot古诗文学习系统 计算机毕业设计原创定制
    摘 要随着科学技术的飞速发展,社会的方方面面、各行各业都在努力与现代的先进技术接轨,通过科技手段来提高自身的优势,古诗文学习系统当然也不能排除在外。古诗文学习系统是以实际运用为开发背景,运用软件工程原理和开发方法,采用springboot技术构建的一个管理系统。整个开发过......
  • 计算机毕业设计原创定制(免费送源码):Java+SpringBoot+MySQL SpringBoot医院人事工资管理
     摘 要随着科学技术的飞速发展,社会的方方面面、各行各业都在努力与现代的先进技术接轨,通过科技手段来提高自身的优势,医院当然也不例外。医院人事工资管理系统是以实际运用为开发背景,运用软件工程原理和开发方法,采用Java技术构建的一个管理系统。整个开发过程首先对软件系......