mysql相关查询语法(自用)

mysql

条件

if

WHERE IF(条件, true执行条件, false执行条件 )

SELECT * FROM  book WHERE IF(price > 120,  btypeid=10,  btypeid=11);

case when

SELECTpp_.id,pp_.project_name 
FROMpv_project pp_CASE 1WHEN trueTHEN1 = 1ELSEpp_.project_name = 'bbbbb'
END 

日期相关

1.mysql查询当天的数据

select * from table where to_days(时间字段) = to_days(now());

2.mysql查询昨天的数据

select * from table where to_days(now( ) ) - to_days( 时间字段名) = 1  

3.mysql查询近一周的数据

SELECT * FROM table WHERE date(时间字段) >= DATE_SUB(CURDATE(),INTERVAL 7 DAY)

4.mysql查询近一个月的数据

SELECT * FROM table WHERE date(时间字段) >= DATE_SUB(CURDATE(),INTERVAL 1 MONTH)

5.mysql查询本月的数据

select * from table where DATE_FORMAT(时间字段, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' ) 

6.mysql查询上月的数据

select * from table where PERIOD_DIFF(date_format(now(),'%Y%m') , date_format(时间字段,'%Y%m')) =1

7.mysql查询本年的数据

select * from table where YEAR(时间字段)=YEAR(now());  

8.mysql查询上一年的数据

select * from table where year(时间字段)=year(date_sub(now(),interval 1 year));  

9.mysql查询本周数据(周一为第一天)

SELECT * FROM table WHERE YEARWEEK(date_format(时间字段,'%Y-%m-%d'),1) = YEARWEEK(now(),1);

10.mysql查询近五分钟的数据

SELECT * FROM table WHERE 时间字段 >= DATE_SUB(now(),INTERVAL 5 MINUTE)

11 过去的12个月

SELECTmon.`month`,IFNULL( tmp.countDelayComplete, 0 ) AS countDelayComplete,IFNULL( tmp.countDelayUnComplete, 0 ) AS countDelayUnComplete,IFNULL( tmp.rate, 0 ) AS rate 
FROM(SELECTDATE_FORMAT( CURDATE(), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 1 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 2 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 3 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 4 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 5 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 6 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 7 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 8 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 9 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 10 MONTH ), '%Y.%m' ) AS `month` UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 11 MONTH ), '%Y.%m' ) AS `month` ) AS monLEFT JOIN (SELECTdate_format( pvr.plan_completion_time, '%Y.%m' ) AS MONTH)

格式化

SELECT date_format( createTime,'%Y-%m-%d') AS createTime 

日期差值

TIMESTAMPDIFF(DAY, pr_.plan_completion_time, NOW()),SELECT TIMESTAMPDIFF(DAY,'1993-03-23 00:00:00',DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%S'))SELECT DATEDIFF('2018-12-01 12:23:59','2018-11-03 12:23:59') FROM DUAL;

类型可选

MICROSECOND
SECOND
MINUTE
HOUR
DAY
WEEK
MONTH
QUARTER
YEAR

示例

SELECTpp_.id AS project_id,pr_.report_num,CONCAT(TIMESTAMPDIFF( DAY, NOW(), pr_.plan_completion_time ),'天',ABS( TIMESTAMPDIFF( HOUR, NOW(), pr_.plan_completion_time ) % 24 ),'时',ABS( TIMESTAMPDIFF( MINUTE, NOW(), pr_.plan_completion_time ) % 60  ),'分' ) AS date,pp_.project_name,pwf_.work_flow_name,pr_.receive_report_time,JSON_UNQUOTE(json_extract( form_data, '$."117"' )) AS '117',JSON_UNQUOTE(json_extract( form_data, '$."155"' )) AS '155',JSON_UNQUOTE(json_extract( form_data, '$."158"' )) AS '158',JSON_UNQUOTE(json_extract( form_data, '$."162"' )) AS '162',JSON_UNQUOTE(json_extract( form_data, '$."163"' )) AS '163',JSON_UNQUOTE(json_extract( form_data, '$."165"' )) AS '165',JSON_UNQUOTE(json_extract( form_data, '$."169"' )) AS '169',JSON_UNQUOTE(json_extract( form_data, '$."175"' )) AS '175',JSON_UNQUOTE(json_extract( form_data, '$."176"' )) AS '176',JSON_UNQUOTE(json_extract( form_data, '$."142"' )) AS '142',JSON_UNQUOTE(json_extract( form_data, '$."145"' )) AS '145',pr_.plan_completion_time,
CASEpr_.STATUS WHEN 'not_finish' THEN'未完成' WHEN 'finish' THEN'已完成' ELSE '延期完成' END AS STATUS,
CASEpr_.is_delay WHEN 0 THEN'即将延期' ELSE '已延期' END AS is_delay 
FROMplm.pv_report pr_LEFT JOIN plm.pv_project pp_ ON pr_.project_id = pp_.idLEFT JOIN plm.pv_project_work_flow pwf_ ON pr_.work_flow_id = pwf_.idLEFT JOIN plm.pv_report_form_data prfd_ ON pr_.id = prfd_.report_id

count

条件count

select count(age <  19 or null) from sys_userselect count(if(age <  19, 1, null)) from sys_user // 返回 1条数据
select count(case when age <  19 then 1 end) from sys_user // 返回 1条数据

位数

一、FORMAT(四舍五入)SELECT FORMAT(4.4289, 2)二、ROUND(四舍五入)SELECT ROUND(4.4289, 2)
三、TRUNCATE(直接舍去)TRUNCATE(X,D)函数会将小数部分2位以后的值直接舍去SELECT TRUNCATE(4.4289, 2)
四、CONVERT(四舍五入)SELECT CONVERT(4.4289,DECIMAL(10,2));
五、CAST(四舍五入)SELECT CAST(4.4289 as DECIMAL(10,2));

分组

字符串拼接

效果: 何庆青,史小辉,蒋铁荣

group_concat( pvcu_.user_name SEPARATOR ‘,’ )

SELECTpvp_.erp_id,pvp_.program_code,pvp_.project_name,group_concat( pvcu_.user_name SEPARATOR ',' ) AS pm 
FROMpv_project pvp_LEFT JOIN pv_project_csp_user pvcu_ ON pvp_.csp_id = pvcu_.csp_id 
GROUP BYpvp_.id

case when

CASE case_valueWHEN when_value THENstatement_listELSEstatement_list
END CASE;示例SELECTppp_.id,ppcu_.user_id,ppcu_.user_name,ppcu_.email,
CASEppcu_.enabled WHEN 1 THEN'正常' ELSE '禁用' 
END AS STATUS 
FROMplm.pv_project ppp_LEFT JOIN pv_project_user ppu_ ON ppp_.id = ppu_.project_idLEFT JOIN pv_project_csp_user ppcu_ ON ppu_.user_id = ppcu_.user_id AND ppp_.csp_id = ppcu_.csp_id
  1、简单函数 CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END2、搜索函数 CASE WHEN [expr] THEN [result1]…ELSE [default] END

JSON处理

insert into userinfo (id, info) values (3,'{"a": 1, "b": 2, "c": {"d": 4},"d":[1,2,3],"e":{"name":"tom","age":12}}');取出元素select json_extract(info,'$.a') from userinfo where id=3; # 1
select json_extract(info,'$.c.d') from userinfo where id=3; # 4
select json_extract(info,'$.d') from userinfo where id=3; # [1,2,3]
select json_extract(info,'$.d[0]') from userinfo where id=3; # 1
select json_extract(info,'$.d[3]') from userinfo where id=3; # NULL

字符串

SELECT CONCAT(字段1,字段2,字段3,...) from 表名;

数学函数

取整 取余

SELECT 10 DIV 3; -- 返回结果为 3SELECT 10 / / 3; -- 返回结果为 3SELECT MOD(10, 3); -- 返回结果为 1SELECT 10 % 3; -- 返回结果为 1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/188257.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++作业3

设计一个Per类&#xff0c;类中包含私有成员:姓名、年龄、指针成员身高、体重&#xff0c;再设计一个Stu类&#xff0c;类中包含私有成员:成绩、Per类对象p1&#xff0c;设计这两个类的构造函数、析构函数和拷贝构造函数。 代码&#xff1a; #include <iostream>using n…

Flutter页面刷新失败?看看是不是这个原因

文章目录 问题描述解决办法在控件A中定义回调函数在页面中使用控件A 原因分析回顾问题原因分析 setState使用注意事项上下文正确性异步更新避免深层嵌套避免频繁调用避免在 build 方法中调用避免在 dispose 方法中调用 问题描述 我用flutter开发了一个页面&#xff0c;页面上有…

Java SpringBoot Controller常见写法

文章目录 环境Controller调用脚本运行结果总结 环境 系统: windows 11 工具: java, idea, git bash Controller 接口常见有以下几种方式 其中&#xff1a; Tobj 调用脚本 我的是windows 系统&#xff0c;使用 git bash 窗口运行, 用 cmd 或者 power shell 会有问题 curl …

8、Qt中定时器的使用

一、说明 在Qt中常使用如下两种定时器 1、使用QObiect类的定时器事件QTimerEvent 与定时器相关的函数有&#xff1a;startTimer()、timeEvent()、killTimer()&#xff1b;startTimer(int interval)函数开始一个定时器并返回定时器ID&#xff0c;如果不能开始一个定时器&…

手把手教你Spring Security Oauth2自定义授权模式

目录 前言1、自定义认证对象2、自定义TokenGranter3、自定义AuthenticationProvider4、配置自定义AuthenticationProvider、自定义TokenGranter5、配置客户端授权模式6、测试 前言 在Oauth2中&#xff0c;提供了几种基本的认证模式&#xff0c;有密码模式、客户端模式、授权码…

传统算法:使用 Pygame 实现选择排序

使用 Pygame 模块实现了选择排序的动画演示。首先,它生成一个包含随机整数的数组,并通过 Pygame 在屏幕上绘制这个数组的条形图。接着,通过选择排序算法对数组进行排序,动画效果可视化每一步的排序过程。在排序的过程中,程序找到未排序部分的最小元素,并将其与未排序部分…

数据结构 / 队列 / 循环队列

1. 定义 为充分利用向量空间&#xff0c;克服假溢出现象的方法是&#xff1a;将向量空间想象为一个首尾相接的圆环&#xff0c;并称这种向量为循环向量。存储在其中的队列称为循环队列&#xff08;Circular Queue&#xff09;。循环队列是把顺序队列首尾相连&#xff0c;把存储…

前端知识笔记(十二)—————前端面试容易问到的问题总结

1.$(document).ready()方法和window.onload有什么区别&#xff1f; 执行时间不同&#xff1a;window.onload必须等到页面内的所有元素&#xff08;&#xff09;加载完毕后才能执行。 $(document).ready()是页面DOM结构绘制完毕后就执行&#xff0c;不必等到加载完毕 执行次数…

字符集与编码规则

字符集 强调&#xff1a;UTF-8是编码规则&#xff0c;不是字符集 过程&#xff1a; 字符 --查表获得对应数字&#xff0c;--编码 解码---查表----获取字符 ASCII码 &#xff1a;一个字节 8bit GBK字符集&#xff08;windows系统默认使用的GBK,系统显示ANSI&#xff09; 存…

西南科技大学信号与系统A实验一(信号的产生与时域运算)

目录 一、实验目的 二、实验原理 三、实验内容 四、思考题 一、实验目的 1、 掌握用matlab软件产生基本信号的方法。 2、 应用matlab软件实现信号的加、减、乘、反褶、移位、尺度变换及卷积运算 二、实验原理 (一) 产生信号波形的方法 利用Matlab软件的信号处…

QLabel实现点击事件

主要是通过安装过滤器&#xff0c;实现点击事件。 事件过滤器的操作&#xff1a; 首先给需要添加事件过滤器的部件注册监听对象&#xff1b; 对象名->installEventFilter(true); 重写eventFilter(QObject *obj, QEvent *event)函数进行处理。 MainWindow::MainWindow(QW…

Java泛型核心知识总结

目录 Java 泛型核心知识总结泛型什么是泛型&#xff1f;有什么用&#xff1f;泛型有哪些限制&#xff1f;为什么&#xff1f;项目中哪里用到了泛型&#xff1f;什么是类型擦除&#xff1f;什么是桥方法&#xff1f; 通配符什么是通配符&#xff1f;有什么作用&#xff1f;通配符…

四、Lua循环

文章目录 一、while(循环条件)二、for&#xff08;一&#xff09;数值for&#xff08;二&#xff09;泛型for&#xff08;三&#xff09;repeat util 既然同为编程语言&#xff0c;那么控制逻辑里的循环就不能缺少&#xff0c;它可以帮助我们实现有规律的重复操作&#xff0c;而…

AIGC-文生视频

stable diffusion&#xff1a; stable diffusion原理解读通俗易懂&#xff0c;史诗级万字爆肝长文&#xff0c;喂到你嘴里 - 知乎个人网站一、前言&#xff08;可跳过&#xff09;hello&#xff0c;大家好我是 Tian-Feng&#xff0c;今天介绍一些stable diffusion的原理&#…

【Python基础】字符集与字符编码

先行了解的知识&#xff1a; 1. 编码和解码 计算机内存储的信息都是二进制表示。 我们看到的英文&#xff0c;数字&#xff0c;汉字等在计算机内如何表示&#xff0c;那就需要编码 计算机内存储的信息需要解析出来&#xff0c;那就是解码 2.字符集与分类 什么是字符集&#xf…

力扣5.最长回文子串

题目描述 思路 1.能够反复利用已判断好的回文子串 2.当子串s[i1,j-1]是回文子串时&#xff0c;只要s[i]s[j]&#xff0c;那么s[i,j]也会是回文子串 3.用好动态规划&#xff0c;具体解释在代码注释里 代码 class Solution {public String longestPalindrome(String s) {int…

Redis分布式锁学习总结

⭐️ 前言 想必大家都有过并发编程的经验&#xff0c;在一个单体应用中&#xff0c;可以通过java提供的各种锁机制来控制多线程对于单体应用中同一资源的并发访问&#xff1b;那么在分布式场景下&#xff0c;想要控制多个应用对于同一外部资源的并发访问&#xff0c;就要用到分…

利用python实现文件压缩打包的功能

主要是利用了zipfile实现文件压缩打包&#xff0c;简单实例代码如下&#xff1a; import zipfilewith zipfile.ZipFile("archive.zip",w) as zipf:zipf.write("config.ini")zipf.write("test.py") 其中的模式 w表示如果没有该文件则创建该文件…

HarmonyOS4.0开发应用(二)【快速学习】

快速学习 创建项目 1.开始创建 2.选择模板 刚开始选择空白的模板即可 3.填写项目信息 这样一个基本项目就创建好了 代码结构 实现Demo(文字动态切换) Entry Component struct Index {State message: string Hello Worldbuild() {Row() {Column() {Text(this.message).fo…

学习笔记三十五:Ingress-controller高可用

Ingress-controller高可用 Ingress-controller高可用特别注意&#xff1a; 通过keepalivednginx实现ingress-nginx-controller高可用安装nginx主备&#xff1a;修改nginx配置文件。主备一样keepalive配置主keepalived备keepalivek8snode1和k8snode2启动服务测试vip是否绑定成功…