Mysql常用函数

更新日期: 2019-03-02阅读: 2.6k标签: mysql

MySQL数据库中提供了很丰富的函数。MySQL函数包括数学函数、字符串函数、日期和时间函数、条件判断函数、系统信息函数、加密函数、格式化函数等。


数学

avg()平均值:忽略值为null的行
count()求数量,使用*时不忽略null的行,指定字段时忽略
floor()向下取整
ceil()向上取整
round(,)四舍五入
truncate(,)不四舍五入
mod(,)取余数
abs()绝对值
power(,)次方
pi()圆周率六位
rand()随机数
sign()大于0返回1,小于0返回-1,否则为0
exp() e的几次方
max()最大值:忽略值为null的行
min()最小值:忽略值为null的行


字符串

char_length()字符数
length()字符串长度
concat()拼接字符串,包含Null,则返回值就是null
concat_wa()以指定分隔符拼接字符串
concat_wa(null,'','') 返回null
concat_wa('-','a','b',null) 返回a-b
upper()=ucase() 转大写
lower()=lcase() 转小写
reverse() 转换大小写
left(,)|right(,)字符串前几个|后几个字符
lpad(x,y,z)|rpad(x,y,z) x按y长度在前|后添加z字符
trim()|ltrim()|rtrim() 去空格
repeat(,次数) 重复指定次数
replace(x,y,z)x字符串把y字符串替换为z
substring(x,y,z) x字符串从y开始截取z长度,y从1开始
strcmp(x,y)字符串比较


日期时间

curdate()=current_date()当前日期
    如:2019-03-01
curtime()=current_time()当前时间
    如:19:01:57
now()=current_timestamp()=sysdate()当前日期和时间
    如:2019-03-01 19:00:16
month(curdate())当前月份
    如:3    
monthname(curdate())当前月份的名字
dayname(curdate())周几名字
    如:Friday
dayofweek(curdate())周几,周天为1
week(now())一年中第几周
year/month/day/hour/minute/second年月日时分秒
datediff() 两个日期相差天数
date_format(日期,"%Y%m%d")


其他

version()版本
connection_id()连接数
database()=schema()当前数据库
user()=current_user()=system_user()=session_user()当前用户
last_insert_id()当前表的上一次auto_increment值
md5() password()加密
format(数字,2)千分位表示并只保留两位小数

链接: https://fly63.com/article/detial/2174

node如何和MySQL进行通信

Node.js与MySQL交互操作有很多库,常用最多的是mysql模块,mysql数注意:安装前先把目录cd到node.exe所在目录下,这样执行安装命令时,这篇文章主要介绍:链接mysql的流程、数据库连接参数说明、MYSQL CURD操作、连接池Pooling connections、断线重连、防止SQL注入

MySQL 常用30种SQL查询语句优化方法

MySQL查询语句优化方法:应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描。对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。

一个案例彻底弄懂如何正确使用 mysql inndb 联合索引

有一个业务是查询最新审核的5条数据,查看当时的监控情况 cpu 使用率是超过了100%,show processlist看到很多类似的查询都是处于create sort index的状态。索引有一个audit_time在左边的联合索引,没有关于status的索引。

mysql数据库使用insert语句插入中文数据报错

在mysql的命令行模式中,通过insert语句插入中文数据的时候报错,类似于下面这样,造成这个错误通常是由于创建数据表的时候使用了不正确的编码格式,可以使用如下命令查看操作的目标数据表的编码格式。

MySQL技术内幕:InnoDB存储引擎

本文绝大部分内容来源《MySQL技术内幕:InnoDB存储引擎》一书。InnoDB存储引擎是多线程模型,其后台有多个不同的后台线程,负责处理不同的任务。

MYSQL中视图的使用

什么是视图?执行一条SQL,将结果集保存在一张虚拟表中。在视图创建后,可以用与表基本相同的方式使用(查询、过滤、排序数据、与其他视图或连结、(添加、更新))视图只是用来查看存储在别处的数据的设施,本身不包含数据,返回的数据也是从其他表检索出来的。

mysql innodb索引原理

innodb存储引擎表是索引组织表,表中数据按照主键顺序存放。其聚集索引就是按照每张表的主键顺序构造一颗B+树,其叶子结点中存放的就是整张表的行记录数据,这些叶子节点成为数据页。

一条sql语句在mysql中是如何执行的

最近开始在学习mysql相关知识,自己根据学到的知识点,根据自己的理解整理分享出来,本篇文章会分析下一个sql语句在mysql中的执行流程,包括sql的查询在mysql内部会怎么流转,sql语句的更新是怎么完成的。

mysql统计行数时到底应该怎么count

每个人在写代码时都有遇到过要获取MYSQL表里数据行数的情况,多数人获取数据表行数时都用COUNT(*),但同时也流传了不少其他方式,比如说COUNT(1)、COUNT(主键)、COUNT(字段)。

MySQL有哪些索引类型?

从数据结构角度B+树索引(O(log(n)));hash索引;FULLTEXT索引(现在MyISAM和InnoDB引擎都支持了);R-Tree索引(用于对GIS数据类型创建SPATIAL索引)

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!