MySQL常用函数、命令汇总

字符串函数

函数 功能
CONCAT(s1,s2,….) 字符串连接
INSERT(str,x,y,instr) 将指定开始标记到结束的字符串替换为指定字符串
LOWER(str) 将字符串所有字符转为小写
UPPER(str) 将字符串所有字符串转为大写
LEFT(str,x) 返回字符串str最左边的x个字符
RIGHT(str,x) 返回字符串str最右边的x个字符
LPAD(str,n,pad) 在str最左边填充n个pad
RPAD(str,n,pad) 在str最右边填充n个pad
LTRIM(str) 去掉字符串str左侧的空格
RTRIM(str) 去掉字符串str右侧的空格
REPEAT(str,x) 返回str重复x次的结果
STRCMP(s1,s2) 比较字符串s1和s2
REPLACE(str,a,b) 用字符串b替换字符串str中所有出现的字符串a
TRIM(str) 去掉字符串行尾和行头的空格
SUBSTRING(str,x,y) 返回从字符串str x位置起y个字符长度的字串

数学函数

函数 功能
ABS(x) 返回x的绝对值
CEIL(x) 返回大于x的最小整数值
FLOOR(x) 返回小于x的最大整数值
MOD(x,y) 返回x/y的模
RAND() 返回 0~1内的随机值
ROUND(x,y) 返回参数x的四舍五入的有y位小数的值
TRUNCATE(x,y) 返回数字x截断位y位小数的结果

日期和时间函数

函数 功能
CURDATE() 返回当前日期
CURTIME() 返回当前时间
NOW() 返回当前的日期和时间
UNIX_TIMESTAMP(date) 返回日期date的UNIX时间戳
FROM_UNIXTIME 返回UNIX时间戳的日期值
WEEK(date) 返回日期date为一年中的第几周
YEAR(date) 返回日期date的年份
HOUR(time) 返回time的小时值
MINUTE(time) 返回time的分钟值
MONTHNAME(date) 返回date的月份名
DATE_FORMAT(date,fmt) 返回按字符串fmt格式日期date值
DATE_ADD(date,interval expr type) 返回一个日期或时间值加上一个时间间隔的时间值
DATEDIFF(expr,expr2) 返回起始时间expr和结束时间expr2之间的天数

流程函数

函数 功能
IF(value,t f) 如果value是真,返回t;否则返回f
IFNULL(value1,value2) 如果value1不为空,返回value1,否则返回value2
CASE WHEN [value1] THEN[result1]…ELSE[default]END 如果value1是真,返回result1,否则返回result
CASE[expr] WHEN [value1]THEN[result1]…ELSE[default]END 如果expr等于value1,返回result1,否则返回default

其他常用函数

函数 功能
DATEBASE() 返回当前数据库名
VERSION() 返回当前数据库版本
USER() 返回当前登录用户名
INET_ATON(ip) 返回ip地址的数字表示
INET_NTOA(num) 返回数字代表的ip地址
PASSWORD(str) 返回字符串str的加密版本
MD5() 返回字符串str的md5值

MYSQL SHOW 命令

命令 注释
desc [table_name] 表信息
show columns from [table_name] 表字段
describe [table_name] 表信息
show create table [table_name] 表创建语句
show create database [database_name] 显示数据库信息
show table status from [database_name] 数据库状态
show tables 显示当前数据库中所有表的名称
show tables from [database_name] 显示当前数据库中所有表的名称(同上)
show databases 显示mysql中所有数据库的名称
show processlist 显示系统中正在运行的所有进程,也就是当前正在执行的查询。
show table status 显示当前使用或者指定的database中的每个表的信息。信息包括表类型和表的最新更新时间
show columns from [table_name] from [database_name] 显示表中列名称
show grants for user_name@localhost 显示一个用户的权限,显示结果类似于grant 命令
show index from [table_name] 显示表的索引
show status 显示一些系统特定资源的信息,例如,正在运行的线程数量
show variables 显示系统变量的名称和值
show privileges 显示服务器所支持的不同权限
show create database [database_name] 显示create database 语句是否能够创建指定的数据库
show create table [table_name] 显示create database 语句是否能够创建指定的数据库
show engies 显示安装以后可用的存储引擎和默认引擎
show innodb status 显示innoDB存储引擎的状态
show logs 显示BDB存储引擎的日志
show warnings 显示最后一个执行的语句所产生的错误、警告和通知
show errors 只显示最后一个执行语句所产生的错误