根据条件按月份和年份获取结果的 MySQL 查询?
您需要使用 OR 条件以及 WHERE 子句。让我们先创建一个表 -
mysql> create table DemoTable ( Id int NOT NULL AUTO_INCREMENT PRIMARY KEY, MonthNumber int, YearNumber int ); Query OK, 0 rows affected (0.22 sec)
使用 insert 命令在表中插入一些记录 -
mysql> insert into DemoTable(MonthNumber,YearNumber) values(11,2018); Query OK, 1 row affected (0.10 sec) mysql> insert into DemoTable(MonthNumber,YearNumber) values(3,2019); Query OK, 1 row affected (0.12 sec) mysql> insert into DemoTable(MonthNumber,YearNumber) values(12,2018); Query OK, 1 row affected (0.08 sec) mysql> insert into DemoTable(MonthNumber,YearNumber) values(1,2019); Query OK, 1 row affected (0.06 sec) mysql> insert into DemoTable(MonthNumber,YearNumber) values(12,2019); Query OK, 1 row affected (0.10 sec) mysql> insert into DemoTable(MonthNumber,YearNumber) values(6,2018); Query OK, 1 row affected (0.12 sec)
使用 select 语句从表中显示所有记录 -
mysql> select *from DemoTable;
这将产生以下输出 -
+----+-------------+------------+ | Id | MonthNumber | YearNumber | +----+-------------+------------+ | 1 | 11 | 2018 | | 2 | 3 | 2019 | | 3 | 12 | 2018 | | 4 | 1 | 2019 | | 5 | 12 | 2019 | | 6 | 6 | 2018 | +----+-------------+------------+ 6 rows in set (0.00 sec)
以下是按月和年获取结果的查询 -
mysql> select Id,MonthNumber,YearNumber from DemoTable where (MonthNumber >= 11 AND YearNumber = 2019) OR (MonthNumber <=11 AND YearNumber = 2018);
这将产生以下输出 -
+----+-------------+------------+ | Id | MonthNumber | YearNumber | +----+-------------+------------+ | 1 | 11 | 2018 | | 5 | 12 | 2019 | | 6 | 6 | 2018 | +----+-------------+------------+ 3 rows in set (0.00 sec)
广告
数据结构
网络
关系型数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP