MySQL学习——行分类及日期计算

1 行分类

你可能已经在前面的例子中注意到,结果行的显示没有特定的顺序。当结果行以某种有意义的方式进行排序时,检查查询输出通常会更容易。要对结果进行排序,请使用ORDER BY子句。

以下是按日期排序的动物生日:

mysql> SELECT name, birth FROM pet ORDER BY birth;+----------+------------+| name     | birth      |+----------+------------+| Buffy    | 1989-05-13 || Bowser   | 1989-08-31 || Fang     | 1990-08-27 || Fluffy   | 1993-02-04 || Claws    | 1994-03-17 || Slim     | 1996-04-29 || Whistler | 1997-12-09 || Chirpy   | 1998-09-11 || Puffball | 1999-03-30 |+----------+------------+

在字符类型的列上,排序——像所有其他比较操作一样——通常是以不区分大小写的方式执行的。这意味着,除了大小写之外完全相同的列的顺序是未定义的。你可以通过使用BINARY来强制对列进行区分大小写的排序,如下所示:ORDER BY BINARY col_name。

默认的排序顺序是升序,即最小的值排在最前面。为了按相反的顺序(降序)排序,可以在你正在排序的列名后添加DESC关键字:

mysql> SELECT name, birth FROM pet ORDER BY birth DESC;+----------+------------+| name     | birth      |+----------+------------+| Puffball | 1999-03-30 || Chirpy   | 1998-09-11 || Whistler | 1997-12-09 || Slim     | 1996-04-29 || Claws    | 1994-03-17 || Fluffy   | 1993-02-04 || Fang     | 1990-08-27 || Bowser   | 1989-08-31 || Buffy    | 1989-05-13 |+----------+------------+

你可以按多个列进行排序,并且可以为不同的列指定不同的排序方向。例如,要按照动物类型以升序排序,然后在每种动物类型内按出生日期以降序排序(最年轻的动物排在最前面),可以使用以下查询:

mysql> SELECT name, species, birth FROM petORDER BY species, birth DESC;+----------+---------+------------+| name     | species | birth      |+----------+---------+------------+| Chirpy   | bird    | 1998-09-11 || Whistler | bird    | 1997-12-09 || Claws    | cat     | 1994-03-17 || Fluffy   | cat     | 1993-02-04 || Fang     | dog     | 1990-08-27 || Bowser   | dog     | 1989-08-31 || Buffy    | dog     | 1989-05-13 || Puffball | hamster | 1999-03-30 || Slim     | snake   | 1996-04-29 |+----------+---------+------------+

DESC关键字仅适用于它紧前面的列名(在此例中是birth);它不会影响其他列(如species)的排序顺序。

日期计算

MySQL提供了几个函数,你可以使用它们来对日期进行计算,例如计算年龄或提取日期的部分信息。

为了确定你的每只宠物的年龄,你可以使用TIMESTAMPDIFF()函数。该函数的参数包括你希望结果以什么单位表示,以及要计算差异的两个日期。以下查询显示了每只宠物的出生日期、当前日期和以年为单位的年龄。使用别名(age)来使最终输出列的标签更有意义。

mysql> SELECT name, birth, CURDATE(),TIMESTAMPDIFF(YEAR,birth,CURDATE()) AS ageFROM pet;+----------+------------+------------+------+| name     | birth      | CURDATE()  | age  |+----------+------------+------------+------+| Fluffy   | 1993-02-04 | 2003-08-19 |   10 || Claws    | 1994-03-17 | 2003-08-19 |    9 || Buffy    | 1989-05-13 | 2003-08-19 |   14 || Fang     | 1990-08-27 | 2003-08-19 |   12 || Bowser   | 1989-08-31 | 2003-08-19 |   13 || Chirpy   | 1998-09-11 | 2003-08-19 |    4 || Whistler | 1997-12-09 | 2003-08-19 |    5 || Slim     | 1996-04-29 | 2003-08-19 |    7 || Puffball | 1999-03-30 | 2003-08-19 |    4 |+----------+------------+------------+------+

查询是有效的,但如果按某种顺序排列行,结果会更容易扫描。这可以通过添加一个ORDER BY name子句来按名称对输出进行排序来实现:

mysql> SELECT name, birth, CURDATE(),TIMESTAMPDIFF(YEAR,birth,CURDATE()) AS ageFROM pet ORDER BY name;+----------+------------+------------+------+| name     | birth      | CURDATE()  | age  |+----------+------------+------------+------+| Bowser   | 1989-08-31 | 2003-08-19 |   13 || Buffy    | 1989-05-13 | 2003-08-19 |   14 || Chirpy   | 1998-09-11 | 2003-08-19 |    4 || Claws    | 1994-03-17 | 2003-08-19 |    9 || Fang     | 1990-08-27 | 2003-08-19 |   12 || Fluffy   | 1993-02-04 | 2003-08-19 |   10 || Puffball | 1999-03-30 | 2003-08-19 |    4 || Slim     | 1996-04-29 | 2003-08-19 |    7 || Whistler | 1997-12-09 | 2003-08-19 |    5 |+----------+------------+------------+------+

要按照年龄而不是名称对输出进行排序,只需使用不同的ORDER BY子句:

mysql> SELECT name, birth, CURDATE(),TIMESTAMPDIFF(YEAR,birth,CURDATE()) AS ageFROM pet ORDER BY age;+----------+------------+------------+------+| name     | birth      | CURDATE()  | age  |+----------+------------+------------+------+| Chirpy   | 1998-09-11 | 2003-08-19 |    4 || Puffball | 1999-03-30 | 2003-08-19 |    4 || Whistler | 1997-12-09 | 2003-08-19 |    5 || Slim     | 1996-04-29 | 2003-08-19 |    7 || Claws    | 1994-03-17 | 2003-08-19 |    9 || Fluffy   | 1993-02-04 | 2003-08-19 |   10 || Fang     | 1990-08-27 | 2003-08-19 |   12 || Bowser   | 1989-08-31 | 2003-08-19 |   13 || Buffy    | 1989-05-13 | 2003-08-19 |   14 |+----------+------------+------------+------+

一个类似的查询可以用来确定已经死亡的动物的死亡年龄。你可以通过检查death值是否为NULL来确定哪些动物已经死亡。然后,对于那些具有非NULL值的动物,计算death和birth值之间的差异:

mysql> SELECT name, birth, death,TIMESTAMPDIFF(YEAR,birth,death) AS ageFROM pet WHERE death IS NOT NULL ORDER BY age;+--------+------------+------------+------+| name   | birth      | death      | age  |+--------+------------+------------+------+| Bowser | 1989-08-31 | 1995-07-29 |    5 |+--------+------------+------------+------+

查询中使用 death IS NOT NULL 而不是 death <> NULL,因为 NULL 是一个特殊值,不能使用常规的比较运算符进行比较。

如果你想知道哪些动物下个月过生日怎么办?对于这类计算,年份和日期是无关紧要的;你只想提取birth列的月份部分。MySQL提供了几个用于提取日期部分的函数,如YEAR()、MONTH()和DAYOFMONTH()。在这里,MONTH()是合适的函数。为了看看它是如何工作的,运行一个简单的查询,显示birth和MONTH(birth)的值:

mysql> SELECT name, birth, MONTH(birth) FROM pet;+----------+------------+--------------+| name     | birth      | MONTH(birth) |+----------+------------+--------------+| Fluffy   | 1993-02-04 |            2 || Claws    | 1994-03-17 |            3 || Buffy    | 1989-05-13 |            5 || Fang     | 1990-08-27 |            8 || Bowser   | 1989-08-31 |            8 || Chirpy   | 1998-09-11 |            9 || Whistler | 1997-12-09 |           12 || Slim     | 1996-04-29 |            4 || Puffball | 1999-03-30 |            3 |+----------+------------+--------------+

要找出下个月过生日的动物也很简单。假设当前是4月,那么月份值是4,你可以像这样寻找5月(5月)出生的动物:

mysql> SELECT name, birth FROM pet WHERE MONTH(birth) = 5;+-------+------------+| name  | birth      |+-------+------------+| Buffy | 1989-05-13 |+-------+------------+

如果当前月份是12月,就会有一点小复杂。你不能仅仅将月份数字(12)加一来寻找13月出生的动物,因为没有这样的月份。相反,你要寻找的是1月(1月)出生的动物。

你可以编写查询,使其无论当前月份是什么都能工作,这样你就不必使用特定月份的数字了。DATE_ADD() 允许你在给定的日期上添加一个时间间隔。如果你在 CURDATE() 的值上加一个月,然后用 MONTH() 提取月份部分,结果就会产生要寻找生日的月份:

mysql> SELECT name, birth FROM petWHERE MONTH(birth) = MONTH(DATE_ADD(CURDATE(),INTERVAL 1 MONTH));

您提到的方法是一种有效的解决方案,它使用模运算(MOD)来处理从12月到1月的过渡。下面是一个具体的SQL查询示例,该查询将找到下个月过生日的宠物,无论当前月份是什么:

mysql> SELECT name, birth FROM petWHERE MONTH(birth) = MOD(MONTH(CURDATE()), 12) + 1;

MONTH() 函数返回 1 到 12 之间的数字,而 MOD(something, 12) 返回 0 到 11 之间的数字。因此,加法运算必须在 MOD() 函数之后进行,以确保结果仍然在 1 到 12 的范围内。这样可以避免从 11 月(11)直接跳到 1 月(1)的情况。

关于无效日期的计算,确实,如果在进行日期计算时使用了无效的日期或时间值,MySQL 可能会产生警告或错误。这通常发生在尝试创建不存在的日期(如 2 月 30 日)或超出日期范围的值时。

mysql> SELECT '2018-10-31' + INTERVAL 1 DAY;+-------------------------------+| '2018-10-31' + INTERVAL 1 DAY |+-------------------------------+| 2018-11-01                    |+-------------------------------+mysql> SELECT '2018-10-32' + INTERVAL 1 DAY;+-------------------------------+| '2018-10-32' + INTERVAL 1 DAY |+-------------------------------+| NULL                          |+-------------------------------+mysql> SHOW WARNINGS;+---------+------+----------------------------------------+| Level   | Code | Message                                |+---------+------+----------------------------------------+| Warning | 1292 | Incorrect datetime value: '2018-10-32' |+---------+------+----------------------------------------+

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

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

相关文章

Windows11 wsl2编译Android14 使用ASfP Debug windows上启动的模拟器

wsl2的安装和配置 安装&#xff1a; 直接百度搜索最新的wsl2安装教程即可&#xff0c;官网&#xff1a;https://learn.microsoft.com/zh-cn/windows/wsl/install 1. 启用适用于 Linux 的 Windows 子系统(以管理员身份打开 PowerShell 并运行) Enable-WindowsOptionalFeature…

Nginx的Map模块

Nginx的map模块是一个功能强大的工具&#xff0c;可以在配置Nginx时实现更高效的请求处理。本文将介绍map模块的基本用法、使用场景、示例以及注意事项。 什么是Nginx的map模块&#xff1f; Nginx的map模块允许我们根据变量的值来映射到对应的值。这个映射可以是静态的&#…

8-Django项目--登录及权限

目录 templates/login/login.html templates/login/404.html views/login.py utils/pwd_data.py auth.py settings.py 登录及权限 登录 views.py 中间件 auth.py templates/login/login.html {% load static %} <!DOCTYPE html> <html lang"en"&g…

Linux系统编程——动静态库

目录 一&#xff0c;关于动静态库 1.1 什么是库&#xff1f; 1.2 认识动静态库 1.3 动静态库特征 二&#xff0c;静态库 2.1 制作静态库 2.2 使用静态库 三&#xff0c;动态库 3.1 制作动态库 3.2 使用动态库一些问题 3.3 正确使用动态库三种方法 3.3.1 方法一&…

什么是BFC?

1、BFC&#xff1a;又叫块级格式化上下文&#xff08;block formatting context&#xff09;&#xff0c;就是页面上一个隔离的独立容器&#xff0c;容器里面的子元素不会影响到外面的元素。 2、BFC的原则&#xff1a;如果一个元素具有BFC&#xff0c;那么内部元素再怎么弄&am…

微信小程序的tabbar怎么配置

微信小程序的tabBar配置是在全局配置文件app.json中进行的&#xff0c;主要用于设置小程序底部的导航栏效果。以下是一个清晰的tabBar配置步骤和示例&#xff1a; 1. 打开app.json文件 这个文件位于小程序项目的根目录下&#xff0c;是微信小程序的全局配置文件。 2. 添加或…

QuillEditor富文本结合vue3使用,可单独抽离成组件,富文本的内容可自定义

实现效果&#xff1a; 上方的粗体、斜体、字号、字体等各种信息支持自定义配置。 实现方式&#xff1a; 下面的介绍为分步骤的详细介绍&#xff0c;完整版纯享代码可参考这篇博客富文本QuillEditorvue3组件代码纯享版-CSDN博客 1.新建一个新文件--子组件&#xff0c;如命名为…

git应用最佳实践

插&#xff1a; AI时代&#xff0c;程序员或多或少要了解些人工智能&#xff0c;前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家(前言 – 人工智能教程 ) 坚持不懈&#xff0c;越努力越幸运&#xff0c;大家…

QGraphicsView实现简易地图19『迁徙图』

模仿echarts的迁徙图效果 用到了前2篇制作的散点(涟漪效果)和两年前的路径动画类&#xff1b;然尾迹效果未依附路径&#xff0c;有待优化。 动态演示效果 静态展示图片 核心代码 #pragma once #include "Item/AbstractGeoItem.h" #include "DataStruct/GeoD…

php之文件操作代码审计

1 PHP文件操作函数 1.1 PHP文件操作函数 文件包含 include/require/include_once/require_once 文件读取 file_get_contents/fread/readfile/file 文件写入 file_put_contents/fwrite/mkdir/fputs 文件删除 unlink/rmdir 文件上传 move_uploaded_file/copy/rename 1.2 文…

python使用MkDocs自动生成文档

python使用MkDocs自动生成文档 前言使用MkDocs环境相关资料使用介绍项目结构配置文件注释生成文档的配置运行与构建部署 实践的项目 前言 python代码注释风格有很多&#xff0c;比较主流的有 reStructuredText风格、numpy风格、Google风格。 自动生成文档的工具也有很多&…

IO流(1)

定义&#xff1a;存取和读取数据的解决方案 作用&#xff1a;用于读写数据&#xff08;本地文件、网络&#xff09; 分类&#xff1a; 一种是&#xff1a;输出流和输入流。 一种是&#xff1a;字节流和字符流。 字节流 字节流——FileOutputStream&#xff08;字节输出流&…

C++标准模板(STL)- 变参数函数

变参数函数 变参数函数是接收可变数量参数的函数&#xff08;例如 std::printf &#xff09;。 为声明变参数函数&#xff0c;要以省略号为最后的形参&#xff0c;例如 int printf(const char* format, ...); 。语法上的额外细节、自动参数转换及替用项见变参数。 为从函数…

L9110S电机控制模块

1.L9110s控制小车前进后退左右 接通VCC&#xff0c;GND 模块电源指示灯亮&#xff0c; 以下资料来源官方&#xff0c;但是仍需我们调制 &#xff08;前进&#xff09;&#xff1a; L1A输入低电平&#xff0c;L1B输入高电平 R1A输入低电平&#xff0c;R1B输入高电平 &a…

智能优化算法 | Matlab实现DBO蜣螂优化算法

智能优化算法 | Matlab实现DBO蜣螂优化算法 文章目录 智能优化算法 | Matlab实现DBO蜣螂优化算法文章概述源码设计文章概述 智能优化算法 | Matlab实现DBO蜣螂优化算法 源码设计 % ----------------------------------------------------------------------------------------…

(函数)判断一句话中最长的单词(C语言)

一、运行结果&#xff1b; 二、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>//声明函数&#xff1b; int aiphabetic(char); int longest(char[]);int main() {//初始化变量值&#xff1b;int i;char line[100] { 0 };//获取用户输入字符…

【HM】使用@Builder装饰器,顺便要知道@BuilderParam,且注意this的指向

Builder装饰器修饰的函数是自定义构造函数&#xff0c;可以定义组件内构造函数&#xff0c;也可以定义全局构造函数&#xff0c;提供给外部组件使用。 就是通过自定义构造函数&#xff0c;可以把build(){// UI元素} 构造函数内的UI部分&#xff0c;抽离出来封装成一个函数&…

Gradle命令打包 Execution failed for task ‘:app:compileDebugJavaWithJavac错误

Gradle命令打包的时候遇到的&#xff0c;Gradle的java版本不对导致的&#xff0c;用的17&#xff0c;换成11的就能正常打包了。

大模型管理工具Ollama搭建及整合springboot

目录 一、Ollama介绍 1.1 什么是Ollama 1.2 Ollama特点与优势 二、Ollama本地部署 2.1 版本选择 2.2 下载安装包 2.3 执行安装 2.4 Ollama常用命令 三、使用Ollama部署千问大模型 3.1 千问大模型介绍 3.2 部署过程 四、springboot接入Ollama 4.1 引入Ollama依赖 4…

树莓派LCD显示屏安装驱动详细教程

使用LCD显示屏有两种方式&#xff0c;1.如果你已安装好树莓派官方系统&#xff0c;需要单独安装驱动才可点亮显示屏。 2. 也可以直接烧录我们提供的系统 里面已含驱动程序。 一&#xff1a;连接方式 按照下图方式连接好LCD显示屏与树莓派主板 二&#xff1a;安装系统镜像&…