SQL中Between查询日期的问题
SQL中Between查询日期的问题
SQL中Between查询日期的问题一、sql between and 取值范围
oracle、mysql、sql server 数据库:大于或等于 begin 的值并且小于或等于 end 的值
二、SQL中Between查询日期的常见几个问题
1、某个表某个字段是Datetime型 以"YYYY-MM-DD 00:00:00" 存放
(1)、例如数据
2009-01-22 21:22:22
2009-01-22 19:21:11
2009-01-22 23:10:22
(2)、用 select * from TABLE where date between '2009-1-22' And '2009-1-22' ,想查日期为2009-1-22的记录,结果查不到
(3)、问题原因
短日期类型默认Time为00:00:00,所以当使用between作限制条件时,就相当于between '2009-1-22 00:00:00' and '2009-1-22 00:00:00',因此就查不出数据。
(4)、解决方法
create table tb(id varchar(1),riqi datetime)
insert into tb values('A' , '2009-01-22 21:22:22')
insert into tb values('B' , '2009-01-22 19:21:11')
insert into tb values('C' , '2009-01-22 23:10:22')
go
--方案一:对数据库里面的字段进行日期格式转换
select * from tb where convert(varchar(10),riqi,120) = '2009-01-22'
--方案二:给日期补全时分秒
select * from tb where riqi between '2009-01-22 00:00:00' and '2009-01-22 23:59:59'
--结果
/*
id riqi
---- ------------------------------------------------------
A 2009-01-22 21:22:22.000
B 2009-01-22 19:21:11.000
C 2009-01-22 23:10:22.000
(所影响的行数为 3 行)
*/
2、某个表某个字段是Datetime型 以"YYYY-MM-DD" 存放
(1)、例如数据
2009-01-22
2009-01-23
2009-01-24
(2)、用 select * from TABLE where date between '2009-1-22 00:00:00' And '2009-1-24 23:59:59' ,想查日期为 2009-1-22 到 2009-1-24 的记录,结果查不到 2009-01-22 的记录
(3)、解决方法
select * from TABLE where date between convert('2009-1-22 00:00:00',riqi,120) And '2009-1-24 23:59:59'
备注:因为有的编程语言传入日期字段时,默认是带 时分秒 '00:00:00',所以需要在数据库中的SQL语句中转换,去掉时分秒。
即确保最终的SQL语句为:
select * from TABLE where date between '2009-1-22' And '2009-1-24 23:59:59'
- mysql记录binlog的方式(MySQL使用binlog日志做数据恢复的实现)
- SqlServer GO命令循环使用实例代码(SqlServer GO命令循环使用实例代码)
- MySql 中IFNULL、ISNULL和NULLIF
- mariadb导入数据库命令(MySQL/MariaDB 如何实现数据透视表的示例代码)
- 终于有人将mysql 索引讲清楚了(MySQL 索引的一些细节分享)
- mysql主从同步复制原理(MYSQL数据库GTID实现主从复制实现超级方便)
- mysql 主从配置详解(MySQL 8.0.15配置MGR单主多从的方法)
- mysql8.0.25安装教程(Mysql8.0.17安装教程推荐)
- 2021-10-28 10:49:05
- sql server表字段数据类型(SQL Server数据库中伪列及伪列的含义详解)
- mpp数据库的客户端工具(xampp默认mysql数据库root密码的修改)
- mysql函数编写(MySQL中sum函数使用的实例教程)
- sqlserver追加主键(sqlserver主键自增的实现示例)
- mysql查看视图注释(详解MySQL的sql_mode查询与设置)
- mysql主从配置教程(MySQL大库搭建主从的一种思路分享)
- mysql的默认数据库例子在哪里(修改MySQL8.0 默认的数据目录快捷操作无配置)
- 冯骥才 年意(冯骥才年意)
- ()
- 百事大吉蓝底 绿底手机高清壁纸(绿底手机高清壁纸)
- 蓝底证件照怎么制作 证件照换底色 换尺寸快速搞定(蓝底证件照怎么制作)
- 你喜欢足球吗 足球如何点亮世界的(足球如何点亮世界的)
- 不可分鸽是什么梗(不可分鸽是什么梗)
热门推荐
- 怎么用docker中的mysql连接数据库(解决Docker之mysql容器数据库更改不生效的问题)
- python表格导出为图片(python生成带有表格的图片实例)
- 宝塔linux面板搭专业版(宝塔linux面板怎么卸载?)
- dedecms文章权重排序(Dedecms实现tags云标签随机颜色与字体大小方法详解)
- docker常用命令详解(docker常用命令总结推荐)
- python中生成字符串序列(python实现字符串加密 生成唯一固定长度字符串)
- python将字符串转换为时间格式(Python时间和字符串转换操作实例分析)
- css3设置过渡效果(CSS3 media queries + jQuery实现响应式导航)
- elementui的el-popover修改样式不生效的解决(elementui的el-popover修改样式不生效的解决)
- php查询数据库给变量赋值(详解PHP变量传值赋值和引用赋值变量销毁)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9