工作上常用的sql写法/函数

这篇具有很好参考价值的文章主要介绍了工作上常用的sql写法/函数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

保留两位小数

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'); 

group by having

作用

where在前是对group by分组之前的筛选,having在后是对group by分组之后的筛选

eg

查找分组之后只有一个的数据

 select * from exam.t_exam_regist ter group by ter.f_exam_id having count(*) = 1 limit 2;

case when = switch case

case 字段名
when 值 then 结果

else 其余结果(默认值)end

eg:

case taar.f_status 
	when 1 then '未开始'
	when 2 then '已通过'
	when 3 then '未通过'
	when 4 then '进行中'
ELSE '未开始' END
	as '状态'

case when 条件 then 结果
else 其余结果 end

EXISTS

作用

根据主查询的数据,每一行都放到子查询中做条件验证,根据验证结果(TRUE 或者 FALSE),TRUE的话该行数据就会保留

eg

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_CONCAT

作用

组连接函数可以返回分组后指定字段的字符串连接形式,并且可以指定排序逻辑(必须和group by 一起用)

eg

SELECT name, GROUP_CONCAT(title ORDER BY id desc  SEPARATOR '-') from order_diy GROUP BY name ORDER BY NULL;

联表更新

作用

更新 emp 表和 dept 表关联数据

eg

update emp, dept set emp.dept_name = dept.dept_namewhere emp.dept_id = dept.dept_id;

ORDER BY 空值 NULL 排序

作用

当字段中存在 null 值时,会对我们的排序结果造成影响。我们可以通过 「ORDER BY IF(ISNULL(title), 1, 0)」 语法将 null 值转换成0或1,来达到将 null 值放到前面还是后面进行排序的效果。

eg

SELECT * FROM test_rollup ORDER BY  IF(ISNULL(title), 0, 1), money;

with rollup 分组统计数据的基础上再进行统计汇总

作用

MySql 中可以使用 with rollup 在分组统计数据的基础上再进行统计汇总,对聚合函数进行求和,注意 with rollup是对 group by 后的第一个字段,进行分组求和。。(不能和orderBy一起用,8.0以后支持)

eg

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 提取临时表别名

作用

「多个子查询都需要使用同一个子查询」的结果,那么就可以用with as,将共用的子查询提取出来,加个别名。后面查询语句可以直接用,对于大量复杂的SQL语句起到了很好的优化作用文章来源地址https://www.toymoban.com/news/detail-486649.html

eg

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';

到了这里,关于工作上常用的sql写法/函数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java中BigDecimal保留两位小数

    方案一: 方案二:#0.00% 表示保留两位小数,.后几个零就是保留几位小数 %号表示会转成百分率。 方案三: 方案四:保留两位小数,不四舍五入 金额以万元展示,保留两位小数 Bigdecimal 通常用来表示和金额相关的数字。 常用的方法有: BigDecimal a. add (BigDecimal b) BigDecimal对象

    2024年02月09日
    浏览(44)
  • Matlab保留小数点后两位

    Matlab保留小数点后两位 在Matlab中,我们经常需要处理数值数据,并在输出结果时保留特定的小数位数。本文将演示如何使用Matlab来保留小数点后两位。 首先,让我们看一个简单的例子。假设我们有一个数值变量x,其值为3.14159265359。我们希望将其保留两位小数并输出。 在上

    2024年02月05日
    浏览(49)
  • Double 转换成String 保留两位小数

    Double 转换成String 保留两位小数 方法一 其中 %.2f 是一个格式化字符串,它指示将数字格式化为两位小数。您可以将 number 替换为要转换的 Double 值。 方法二 可以使用Java的DecimalFormat类来实现: 输出结果为:3.14 其中,DecimalFormat的模式字符串中的“#”表示可选数字,如果该位

    2024年02月14日
    浏览(44)
  • vue html页面运算,保留两位小数

    有时候我们需要对各种数值进行保留位数,以便于更好的展示。 template中这样使用,需要处理的字段名,再加上过滤器方法 使用filters,与同级data()

    2024年02月11日
    浏览(61)
  • js保留两位小数最简单的6种方法

    日常开发中,后台会返给我们各式各样的数据,如果后台给你返回如下数据时,是不是就已经压制不住心中的怒火了,别急,其实前端处理这些数据还是非常简单的,下面用最简单的方法教你如何1分钟处理好这些数据。 返回数据示例: 3.1415926535897 85.452655625313 99.128532659596

    2024年02月10日
    浏览(45)
  • Java中整数相除并保留两位小数的实现方式、保留两位小数:Java中整数相除的处理方法、解决Java整数相除后精度丢失的问题、Java数值计算:整数相除保留指定小数位数的技巧

    当在Java中需要进行整数相除并保留两位小数时,可以使用以下两种方式实现: 1. 使用浮点数类型和DecimalFormat进行格式化:  2. 使用BigDecimal类进行精确的数值计算和格式化输出: 在选择使用哪种方式时,需要根据具体的业务需求和数值计算的精度要求进行权衡和选择。如果

    2024年02月12日
    浏览(42)
  • 在 JavaScript 中,保留小数点后两位的方法

    在 JavaScript 中,有多种方法可以保留小数点后两位。以下是其中的一些方法: 1. toFixed() 方法:该方法将数字转换为字符串,并保留指定的小数位数。 2. Math.round() 方法:该方法将数字四舍五入到指定的小数位数。  3. parseFloat() 和正则表达式:该方法将字符串转换为数字,并

    2024年02月12日
    浏览(40)
  • chatgpt赋能python:Python中保留两位小数输出的方法:一个完整的指南

    在Python编程中,有时候我们需要将数字保留到小数点后两位输出。例如,货币单位到分、科学计算等等。本文将介绍多种方法实现这个目标,包括Python的内置函数以及第三方库的函数。 Python的内置函数 round() 可以用来对数字进行四舍五入操作。而我们只需要将它的第二个参数

    2024年02月09日
    浏览(44)
  • elementui动态表单实现计算属性携带参数,并将计算出的值四舍五入保留两位小数

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 写项目的时候,遇到需要在动态表单中,将同一级输入框输入的内容计算出来,并动态显示,发现computer计算属性好像不能带参数,最后查了好多文档才解决,看下面简单案例 vue中computed计算属性无法直

    2024年02月14日
    浏览(39)
  • SQL删除重复的记录(只保留一条)-窗口函数row_number()

    关于删除mysql表中重复数据问题,本文中给到两种办法:聚合函数、窗口函数row_number()的方法。 (注意:MySQL从8.0开始支持窗口函数) 测试数据准备:首先创建一个测试表test,插入一些测试数据,模拟一些重复数据(最终目标:删除重复数据,但不处理null行) 先查询下重复数

    2024年02月05日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包