10 :十进制
2:两位小数
100:除数
convert(taar.f_score/100,decimal(10,2))
FROM_UNIXTIME(f_submit_time/1000, '%Y-%m-%d %T');
UNIX_TIMESTAMP(NOW()) * 1000;
FROM_UNIXTIME(UNIX_TIMESTAMP(NOW()) * 1000/1000, '%Y-%m-%d %T');
where在前是对group by分组之前的筛选,having在后是对group by分组之后的筛选
查找分组之后只有一个的数据
select * from exam.t_exam_regist ter group by ter.f_exam_id having count(*) = 1 limit 2;
case 字段名
when 值 then 结果
…
else 其余结果(默认值)end
case taar.f_status
when 1 then '未开始'
when 2 then '已通过'
when 3 then '未通过'
when 4 then '进行中'
ELSE '未开始' END
as '状态'
case when 条件 then 结果
else 其余结果 end
根据主查询的数据,每一行都放到子查询中做条件验证,根据验证结果(TRUE 或者 FALSE),TRUE的话该行数据就会保留
SELECT * from emp e where exists (SELECT * from dept p where e.dept_id = p.dept_id and e.dept_name != p.dept_name)
组连接函数可以返回分组后指定字段的字符串连接形式,并且可以指定排序逻辑(必须和group by 一起用)
SELECT name, GROUP_CONCAT(title ORDER BY id desc SEPARATOR '-') from order_diy GROUP BY name ORDER BY NULL;
更新 emp 表和 dept 表关联数据
update emp, dept set emp.dept_name = dept.dept_namewhere emp.dept_id = dept.dept_id;
当字段中存在 null 值时,会对我们的排序结果造成影响。我们可以通过 「ORDER BY IF(ISNULL(title), 1, 0)」 语法将 null 值转换成0或1,来达到将 null 值放到前面还是后面进行排序的效果。
SELECT * FROM test_rollup ORDER BY IF(ISNULL(title), 0, 1), money;
MySql 中可以使用 with rollup 在分组统计数据的基础上再进行统计汇总,对聚合函数进行求和,注意 with rollup是对 group by 后的第一个字段,进行分组求和。。(不能和orderBy一起用,8.0以后支持)
SELECT name, SUM(money) as money FROM order_diy GROUP BY name WITH ROLLUP;
SELECT coalesce(name, '总金额') name, SUM(money) as money FROM order_diy GROUP BY name WITH ROLLUP;
「多个子查询都需要使用同一个子查询」的结果,那么就可以用with as,将共用的子查询提取出来,加个别名。后面查询语句可以直接用,对于大量复杂的SQL语句起到了很好的优化作用
with aswith t1 as (SELECT * from order_diy where money > 30),t2 as (SELECT * from order_diy where money > 60)SELECT * from t1 where t1.id not in (SELECT id from t2) and t1.name = '周伯通';
INSERT INTO `news` (`news_title`, `news_auth`, `news_code`) VALUES ('新闻3', '小花', 'wx-0003') on duplicate key update news_title = '新闻3';-- 第二次执行修改语句INSERT INTO `news` (`news_title`, `news_auth`, `news_code`) VALUES ('新闻4', '小花', 'wx-0003') on duplicate key update news_title = '新闻4';