SELECT CONVERT("",SIGNED);
SELECT CAST("" AS SIGNED);
SELECT ""+; SELECT LENGTH("姜浩真帅!"); SELECT ABS(-); SELECT CONCAT("","",""); SELECT LEFT("abcdef") SELECT REPLACE("姜浩真帅","真","特别") SELECT CAST("" AS SIGNED)

ABS(X) 返回X的绝对值
CEIL(X) 向上取整  1.5->2 -1.5->-1
FLOOR(X) 向下取整  1.5->1 -1.5->-2
ROUND(X) 四舍五入取整
ROUND(X,D) 将X保留D位小数,进行四舍五入
`TRUNCATE`(X,D) 将X保留D位小数,不进行四舍五入
RAND() 返回随机数
SIN(X) 返回x的符号,x是负数、0、正数分别返回-1、0、1 SELECT SIGN(-10)--(-1)
POW(X,Y)  返回x的y次幂
PI() 返回圆周率

[字符串函数]
LENGTH(str)  返回字符串的长度,其中一个中文占三个长度
CHAR_LENGTH(str) 返回字符串的字符数,其中一个中文只占一个字符
CONCAT(str1,str2,...) 拼接多个字符串
UPPER(str) 将字符串全部转为大写
LOWER(str) 将字符串全部转为小写
LEFT(str,n) 返回字符串的前N个字符
RIGHT(str,n) 返回字符串的后N个字符
TRIM(str) 去掉str左右两边的空格
REPLACE(str,s1,a2); 将字符串中所有的s1换成a2
SUBSTRING(str,pos[,len])截取字符串str 从pos个字符开始,截取len个,如果省略len,则截取到最后
INSTR(s1,s2) 返回s1在字符串中的下标

[字符串转数字格式]

[常用日期函数]
CURDATE();返回当前日期  2017-06-20
CURTIME(); 返回当前时间  09:52:52
NOW(); 返回当前的日期和时间 2017-06-20 09:53:45
DATEDIFF(date1,date2) 返回date1和date2之间的间隔天数
ADDDATE(datetime1,days) 返回datetime1加上days天后的日期
MONTH() 返回日期中的月份
YEAR() 返回日期中的年份
DAY() 返回日期中一个月中的第几天
WEEKDAY() 返回一周中的第几天,0 -> 周一
HOUR() 返回小时数
MINUTE() 返回分钟数
SECOND() 返回秒数

DATE_FORMAT(date,format) 将date使用format要求的格式显示

format中可用的占位符格式:

%Y年份, 数字形式,4位数
%y年份, 数字形式 (2位数)

%M月份名称 (January..December)
%m月份, 数字形式 (00..12)
%b月份的缩写名称  (Jan..Dec)
%c月份,数字形式(0..12)

%D带有英语后缀的该月日期  (0th, 1st, 2nd, 3rd, ...)
%d该月日期, 数字形式 (00..31)
%e该月日期, 数字形式(0..31)
 
%H小时(00..23)
%h小时(01..12)
%k小时(0..23)
%l小时(1..12)
 
%i分钟,数字形式 (00..59)

%S秒 (00..59)
%s秒 (00..59)
 
%W工作日名称 (周日..周六)
%w一周中的每日 (0=周日..6=周六)

SELECT CURDATE();
SELECT CURTIME();
SELECT NOW();
SELECT DATEDIFF("2017-06-21","2017-06-23");
SELECT ADDDATE(NOW(),);
SELECT MONTH()

【系统信息函数】
VERSION() 取到当前数据库的版本号
DATABASE() 返回当前数据库的名字
USER() 返回当前数据库的用户
CONNECTION_ID() 返回服务器的连接数
CHARSET(str) 返回字符串的字符集
LAST_INSERT_ID() 返回最后一个auto_increment的值

[加密函数]
1、PASSWORD() 对字符串进行加密,常用于加密密码
2、MD5():对字符串进行MD5散列加密,常用于不需要解密的数据
3、ENCODE(str,pwd) 使用加密密码pwd对字符串str进行加密,加密之后的结果为二进制,该字段需要使用BLOB类型保存
   DECODE(mistr,pwd) 将ENCODE加密的二进制进行解密,解密密码需要与ENCODE的加密密码一致

SELECT PASSWORD("jianghao")

SELECT ENCODE("juianghao","pwd");
SELECT DECODE(ENCODE("juianghao","pwd"),"pwd"); SELECT DATE_FORMAT("2017-06-20 09:53:45","%Y") UPDATE `Card` SET `PASSWORD` = REPLACE(REPLACE(`PASSWORD`,"O",""),"i",""); INSTR(ListNumber,"-");
LEFT(ListNumber,INSTR(ListNumber,"-")-);
SUBSTRING(ListNumber,INSTR(ListNumber,"-")+); SELECT * FROM SellRecord ORDER BY LEFT(ListNumber,INSTR(ListNumber,"-")-)+ DESC,SUBSTRING(ListNumber,INSTR(ListNumber,"-")+),DESC;

 [多行函数]
SUM(expr) 求和 SELECT SUM(age) FROM tb1;
AVG();求平均值 SELECT AVG(age) FROM tb1;
MIN(expr); 求最小值
MAX(expr);求最大值
COUNT(1);  求总个数 SELECT COUNT(*) FROM tb1

USE mydb;
SELECT * FROM tb1;
SELECT COUNT(*) FROM tb1 SELECT SUM(age) FROM tb1; SELECT AVG(age) FROM tb1 GROUP BY sex HAVING AVG(age)>;

{分组操作}
GROUP BY ----FROM <表名>
WIERE
GROUP BY
HAVING
上述代码执行难执行流程
1线 SELECT.....FROM  查询所有数据
② 使用where 将数据源进行帅选
③ 对wher帅选后的数据,使用GTOUP BY进行分组
   分组后,使用聚合函数,将会产生n条数据
④ HAVING字句对产生的多条聚合数据,进行处理操作
注意事项
① 代码顺序必须是  WHERE GROUP BY  HAVING
② 有HAVING字句。必须有group BY,有group BY 并不一定有HAVING
③ WHERE和 HAVING 的区别

WHERE实在分组之前先筛选数据。HAVING是对分组后的数据,新型筛选,农行订单
  HAVING语句中一定不能包含就、䄦函数,having 是专门用来过滤
-- 求出,平进均薪资大于1万,门对的平均薪资
-- 注 各部门只统计出勤率大于15天的员工
SELECT AVG(薪资)  FROM 公司表 WHERE 出勤率>15
GROUP BY 部门 HAVING AVG(薪资)>10000;

[表连接]

使用WHERE进行多表连接
 与内连接一致
USE mydb;
SELECT i.cusname"客户名称",o.ordmoney"订单总额" -- 多表关联,字段前必须有表名
FROM cusorder AS o,cusinfo as i-- 为方便书写,给表起别名
WHERE o.cusno = i.cusno -- 两张表通过那个键关联

内连接
 特点 相关联的两张表,总是以数据少的为准,另一张表中没有被匹配的行,会被删除不显示
USE mydb;
SELECT i.cusname"客户名称",o.ordmoney"订单总额" -- 多表关联,字段前必须有表名
FROM cusorder AS o INNER JOIN cusinfo as i-- 为方便书写,给表起别名
ON o.cusno = i.cusno -- 两张表通过那个键关联
 
左链接 LEFT JOIN
特点 以左边的表为准,
把左表的全部数据显示,右表多的删除不显示,右表少的补null
USE mydb;
SELECT i.cusname"客户名称",o.ordmoney"订单总额" -- 多表关联,字段前必须有表名
FROM cusorder AS o LEFT JOIN  cusinfo as i-- 为方便书写,给表起别名
ON o.cusno = i.cusno -- 两张表通过那个键关联

右链接 right JOIN
特点 以右边的表为准,
把右表的全部数据显示,左表多的删除不显示,左表少的补null
USE mydb;
SELECT i.cusname"客户名称",o.ordmoney"订单总额" -- 多表关联,字段前必须有表名
FROM cusorder AS o RIGHT JOIN cusinfo as i-- 为方便书写,给表起别名
ON o.cusno = i.cusno -- 两张表通过那个键关联

自连接 同一张表与自己链接
USE mydb;
SELECT e1.ename,e2.ename
FROM emp e1 LEFT JOIN emp e2
ON e1.mgr = e2.empno;
[限制行数]
LIMIT n 表示的前N条数据,相当于LIMIT 0,n
LIMIT n,m 第n+1 到 第m条

SELECT * FROM tb1 LIMIT ,;

@page = 1; -- 第几页
@rows = 5; -- 每页几条
分页语句

SELECT * FROM cusborder LIMIT @rows*(@page-),@rows*@page;

各种限制语句的顺序

SELECT * FROM cusorder
WHERE NOT ISNULL(ordno)
GROUP BY ordno
HAVING SUM(ordmoney)>
ORDER BY ordmoney DESC
LIMIT ,;

MYSQL常用函数以及分组操作的更多相关文章

  1. mysql常用函数参考

    mysql常用函数参考   对于针对字符串位置的操作,第一个位置被标记为1. ASCII(str) 返回字符串str的最左面字符的ASCII代码值.如果str是空字符串,返回0.如果str是NULL, ...

  2. 学生选课数据库SQL语句45道练习题整理及mysql常用函数(20161019)

    学生选课数据库SQL语句45道练习题: 一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四 ...

  3. MySQL常用函数介绍

    MySQL常用函数介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.操作符介绍 1>.操作符优先级 mysql; +----------+ | +----------+ ...

  4. MySql常用函数大全

    MySql常用函数大全 MySQL数据库中提供了很丰富的函数.MySQL函数包括数学函数.字符串函数.日期和时间函数.条件判断函数.系统信息函数.加密函数.格式化函数等.通过这些函数,可以简化用户的操 ...

  5. Mysql 常用函数(4)- case 函数

    Mysql常用函数的汇总,可看下面系列文章 https://www.cnblogs.com/poloyy/category/1765164.html case 的作用 if 的高级版,类似Java 里 ...

  6. 第十章 MySQL 常用函数

    第十章 MySQL 常用函数 第一节:日期和时间函数 1,CURDATE() 返回当前日期:2,CURTIME() 返回当前时间:3,MONTH(d) 返回日期 d 中的月份值,范围是 1~12 第二 ...

  7. 【数据库】MySql常用函数梳理

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/5866388.html MySql常用函数梳理: 1:数学函数 使用格式:一般用于插入.修改语句中,直接 函数( ...

  8. mysql常用快速查询修改操作

    mysql常用快速查询修改操作 一.查找并修改非innodb引擎为innodb引擎 # 通用操作 mysql> select concat('alter table ',table_schema ...

  9. MySQL 常用函数介绍

    MySQL 基础篇 三范式 MySQL 军规 MySQL 配置 MySQL 用户管理和权限设置 MySQL 常用函数介绍 MySQL 字段类型介绍 MySQL 多列排序 MySQL 行转列 列转行 M ...

随机推荐

  1. iOS 设备定位功能可用的判断

    if ([CLLocationManager locationServicesEnabled] && ([CLLocationManager authorizationStatus] ...

  2. linux系统下运行java项目的脚本编写

    本文主要讲linux系统下运行jar包,至于如何打包jar包,放到linux系统下可以参考其他的博客. 在linux系统下运行jar包的命令如下: 1.java -jar xxxxx.jar  //  ...

  3. Struts2框架action层学习心得体会

    在struts2框架中,当action处理完之后,就应该向用户返回结果信息,该任务被分为两部分:结果类型和结果本身. 结果类型提供了返回给用户信息类型的实现细节.结果类型通常在Struts2中就已预定 ...

  4. 感想篇:7)知其然与知其所以然,KnowHow与KnowWhy

    本章目的:探究--知其然与知其所以然,KnowHow与KnowWhy. 1.Know-How体系与代价: 100多年的汽车研发历史表明,企业只有开发过两代车以上才能逐步建立和完善Know-How体系. ...

  5. 评估指标:ROC,AUC,Precision、Recall、F1-score

    一.ROC,AUC ROC(Receiver Operating Characteristic)曲线和AUC常被用来评价一个二值分类器(binary classifier)的优劣 . ROC曲线一般的 ...

  6. Codeforces - tag::data structures 大合集 [占坑 25 / 0x3f3f3f3f]

    371D 小盘子不断嵌套与大盘子,最后与地面相连,往里面灌水,溢出部分会往下面流,求每次操作时当前的盘子的容量 其实这道题是期末考前就做好了的.. 链式结构考虑并查集,然后没了(求大佬解释第一个T的点 ...

  7. 用servlet进行用户名和密码校验01

    用servlet进行用户名和密码校验01 编写一个servlet进行用户名和密码校验,获取登录页面的用户名密码,并显示出来 1.工作目录结构 2.首先是一个login.html,包含非常简单的登录表单 ...

  8. 问题诊断神器arthas

    https://github.com/alibaba/arthas 镜像地址 https://gitee.com/arthas/arthas OGNL https://commons.apache.o ...

  9. C#的datatable使用

    // 构造datatable DataTable dt = new DataTable("test_table"); dt.Columns.AddRange(new DataCol ...

  10. Java - 自定义异常(尚学堂第六章异常机制作业计算平均数)

    编写一个计算N个学生分数平均分的程序.程序应该提示用户输入N的值,如何必须输入所有N个学生分数.如果用户输入的分数是一个负数,则应该抛出一个异常并捕获,提示“分数必须是正数或者0”.并提示用户再次输入 ...