常用函数

字符串函数

  • ASCII(char):返回字符的ASCII码值。
  • BIT_LENGTH(str):返回字符串的比特长度。
  • CONCAT(s1,s2…,sn):将s1,s2…,sn连接成字符串。任何字符串与NULL连接的结果都是NULL。
  • CONCAT_WS(sep,s1,s2…,sn) 将s1,s2…,sn连接成字符串,并用sep字符间隔。
  • INSERT(str,x,y,instr) 将字符串str从第x位置开始,y个字符长的子串替换为字符串instr
  • FIND_IN_SET(str,list) 分析逗号分隔的list列表,如果发现str,返回str在list中的位置
  • LCASE(str)或LOWER(str) 返回将字符串str中所有字符改变为小写后的结果。
  • UCASE(str)或UPPER(str) 返回将字符串str中所有字符转变为大写后的结果。
  • LEFT(str,x) 返回字符串str中最左边的x个字符。如果第二个参数为NULL,则不返回任何字符串。
  • RIGHT(str,x) 返回字符串str中最右边的x个字符。如果第二个参数为NULL,则不返回任何字符串。
  • LENGTH(str) 返回字符串str中的字符数。
  • POSITION(substr,str) 返回子串substr在字符串str中第一次出现的位置。
  • REPEAT(str,srchstr,rplcstr) 返回字符串str重复x次的结果。
  • REVERSE(str) 返回颠倒字符串str的结果。
  • LTRIM(str) 去掉字符串str开头的空格
  • RTRIM(str) 去掉字符串str尾部的空格
  • TRIM(str) 去除字符串首部和尾部的所有空格。
  • replace(str,a,b):用字符串b替换str中所有出现的字符串a。
  • strcmp(s1,s2):比较两个字符串的ASCII码值的大小。
  • substring(str,x,y):返回子串。

数值函数

  • ABS(x) 返回x的绝对值
  • BIN(x) 返回x的二进制(OCT返回八进制,HEX返回十六进制)
  • EXP(x) 返回值e(自然对数的底)的x次方
  • GREATEST(x1,x2,…,xn) 返回集合中最大的值
  • LEAST(x1,x2,…,xn) 返回集合中最小的值
  • LOG(x,y) 返回x的以y为底的对数
  • MOD(x,y) 返回x/y的模(余数),任意一个操作数是NULL就返回NULL。
  • PI() 返回pi的值(圆周率)
  • RAND() 返回0到1内的随机值,可以通过提供一个参数(种子)使RAND()随机数生成器生成一个指定的值。
  • FLOOR(x) 返回小于x的最大整数值,(去掉小数取整)
  • CEILING(x) 返回大于x的最小整数值,(进一取整)
  • ROUND(x,y) 返回参数x的四舍五入的有y位小数的值,(四舍五入)。如果不写y,则默认y为0
  • TRUNCATE(x,y) 返回数字x截断为y位小数的结果
  • SIGN(x) 返回代表数字x的符号的值(正数返回1,负数返回-1,0返回0)
  • SQRT(x) 返回一个数的平方根

日期和时间函数

  • DATE_FORMAT(date,fmt) 依照指定的fmt格式格式化日期date值
  • MONTHNAME(date) 返回date的月份名(英语月份,如October)
  • DAYNAME(date) 返回date的星期名(英语星期几,如Saturday)
  • NOW() 返回当前的日期和时间 (2016-10-08 18:57:39)。
  • CURDATE()或CURRENT_DATE() 返回当前的日期(年月日)。
  • CURTIME()或CURRENT_TIME() 返回当前的时间(时分秒)。
  • QUARTER(date) 返回date在一年中的季度(1~4)
  • WEEK(date) 返回日期date为一年中第几周(0~53)
  • DAYOFYEAR(date) 返回date是一年的第几天(1~366)
  • DAYOFMONTH(date) 返回date是一个月的第几天(1~31)
  • DAYOFWEEK(date) 返回date所代表的一星期中的第几天(1~7)
  • YEAR(date) 返回日期date的年份(1000~9999)
  • MONTH(date) 返回date的月份值(1~12)
  • DAY(date) 返回date的天数部分
  • HOUR(time) 返回time的小时值(0~23)
  • MINUTE(time) 返回time的分钟值(0~59)
  • SECOND(time) 返回time的秒值(0-59)
  • DATE(datetime) 返回datetime的日期值
  • TIME(datetime) 返回datetime的时间值
  • datediff(d1,d2) 计算两个日期之间相差的天数
  • DATE_ADD(date,INTERVAL int keyword) 返回日期date加上间隔时间int的结果(int必须按照关键字进行格式化),如:SELECT DATE_ADD(CURRENT_DATE(),INTERVAL 6 MONTH);
  • DATE_SUB(date,INTERVAL int keyword) 返回日期date减去间隔时间int的结果(int必须按照关键字进行格式化),如:SELECT DATE_SUB(CURRENT_DATE(),INTERVAL 6 MONTH);

流程函数

实现条件选择

下面创建一个职员薪水的表,进行说明:

mysql> create table salary (
    -> userid int,
    -> salary decimal(9,2)
    -> );
Query OK, 0 rows affected (0.02 sec)

mysql> alter table salary modify userid int primary key;
Query OK, 0 rows affected (0.03 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table salary modify userid int auto_increment;
Query OK, 0 rows affected (0.02 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> desc salary;
+--------+--------------+------+-----+---------+----------------+
| Field  | Type         | Null | Key | Default | Extra          |
+--------+--------------+------+-----+---------+----------------+
| userid | int(11)      | NO   | PRI | NULL    | auto_increment |
| salary | decimal(9,2) | YES  |     | NULL    |                |
+--------+--------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

进行初始化表:

mysql> insert into salary(salary) values(1000),(2000),(3000),(4000),(5000),(null);
Query OK, 6 rows affected (0.01 sec)
Records: 6  Duplicates: 0  Warnings: 0

mysql> select * from salary;
+--------+---------+
| userid | salary  |
+--------+---------+
|      1 | 1000.00 |
|      2 | 2000.00 |
|      3 | 3000.00 |
|      4 | 4000.00 |
|      5 | 5000.00 |
|      6 |    NULL |
+--------+---------+
6 rows in set (0.00 sec)
mysql> select if(salary>1000,'high','low') from salary;
+------------------------------+
| if(salary>1000,'high','low') |
+------------------------------+
| low                          |
| high                         |
| high                         |
| high                         |
| high                         |
| low                          |
+------------------------------+
6 rows in set (0.00 sec)

替换NULL值:
mysql> select ifnull(salary,0) from salary;
+------------------+
| ifnull(salary,0) |
+------------------+
|          1000.00 |
|          2000.00 |
|          3000.00 |
|          4000.00 |
|          5000.00 |
|             0.00 |
+------------------+
6 rows in set (0.00 sec)

mysql> select case when salary<=2000 then 'low' else 'high' end from salary;
+---------------------------------------------------+
| case when salary<=2000 then 'low' else 'high' end |
+---------------------------------------------------+
| low                                               |
| low                                               |
| high                                              |
| high                                              |
| high                                              |
| high                                              |
+---------------------------------------------------+
6 rows in set (0.00 sec)

mysql> select case salary when 1000 then 'low' when 2000 then 'mid' else 'high' end from salary;
+-----------------------------------------------------------------------+
| case salary when 1000 then 'low' when 2000 then 'mid' else 'high' end |
+-----------------------------------------------------------------------+
| low                                                                   |
| mid                                                                   |
| high                                                                  |
| high                                                                  |
| high                                                                  |
| high                                                                  |
+-----------------------------------------------------------------------+
6 rows in set (0.00 sec)

聚合函数

常用于GROUP BY从句的SELECT查询中
下面五个函数会忽略值为NULL的行
- AVG(col) 返回指定列的平均值
- COUNT(col) 返回指定列中非NULL值/行的个数(当函数参数为星号*时不会忽略)
- MIN(col) 返回指定列的最小值
- MAX(col) 返回指定列的最大值
- SUM(col) 返回指定列的所有值之和


其他常用函数

mysql> select database();
+------------+
| database() |
+------------+
| test       |
+------------+
1 row in set (0.00 sec)

mysql> select version();
+------------+
| version()  |
+------------+
| 5.7.18-log |
+------------+
1 row in set (0.00 sec)

mysql> select user();
+----------------+
| user()         |
+----------------+
| root@localhost |
+----------------+
1 row in set (0.00 sec)

返回IP地址的网络字节序表示:
mysql> select inet_aton('192.168.1.1');
+--------------------------+
| inet_aton('192.168.1.1') |
+--------------------------+
|               3232235777 |
+--------------------------+
1 row in set (0.00 sec)

返回网络字节序代表的IP地址:
mysql> select inet_ntoa(11111);
+------------------+
| inet_ntoa(11111) |
+------------------+
| 0.0.43.103       |
+------------------+
1 row in set (0.01 sec)

mysql> select md5('123');
+----------------------------------+
| md5('123')                       |
+----------------------------------+
| 202cb962ac59075b964b07152d234b70 |
+----------------------------------+
1 row in set (0.00 sec)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值