| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 552 人关注过本帖
标题:再求高手SQL语句
只看楼主 加入收藏
btcj
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2006-3-24
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:6 
再求高手SQL语句
有一个表中包含有日期、时间,但日期和时间被放在两个字段里,且两个字段均为char类型,我要查询某一时间段内的数据,查询条件应如何写?
如:表为
date      time  dd
2010910   0900  23
2010910   1300  21
2010910   2200  29
2010911   1300  19
2010911   2200  27
2010912   1300  22
2010912   1600  18
2010913   1900  24
要查询2010-9-10 13:00:00到2010-9-11 23:00:00间的数据得到下表结果
date      time  dd
2010910   1300  21
2010910   2200  29
2010911   1300  19
2010911   2200  27
查询的时间条件应如何写?
搜索更多相关主题的帖子: 语句 SQL 
2010-09-20 10:40
红色警戒
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:19
帖 子:444
专家分:2967
注 册:2005-11-20
收藏
得分:0 
把时间格式化成和数据库中格式相同的字符串,然后查询
select * form tablename where date >= strdate1 and time > strtime1 and date <= strdate2 and time <= strtime2

2010-09-20 16:20
aei135
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:12
帖 子:232
专家分:1176
注 册:2009-4-6
收藏
得分:0 
应该是20100910吧?
2010-09-20 18:07
zhaoyang1008
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:30
专家分:110
注 册:2010-9-15
收藏
得分:0 
把date格式化为9-10-2010,time格式化为13:00,依此类推然后执行这个查询
select *
from Table
where (CAST(date as datetime) between '9-10-2010' and '9-11-2010') and (CAST(time as datetime) between '13:00' AND '21:00')
就可以了
其中cast函数是改变数据类型的,把char类型改为了datetime类型
2010-09-20 20:19
yc634998090
Rank: 1
来 自:石家庄
等 级:新手上路
帖 子:1
专家分:0
注 册:2010-9-20
收藏
得分:0 
我是个菜鸟,如果不对请各位高手见谅。
我觉得可以把date和time字段合并起来再求。代码如下:
select  rtrim(date)+ltrim(time) as dt into #t from t2
select dt from #t  where dt>=201009101300 and dt<=201009112300
drop table #t

小菜鸟,但是却有成为鹰的梦想
2010-09-20 22:55
wangwenting2
Rank: 2
等 级:论坛游民
帖 子:1
专家分:10
注 册:2010-9-20
收藏
得分:10 
菜鸟来访
CREATE TABLE TimeTest
(
   date VARCHAR(10),
   [time] VARCHAR(10),
   DATA VARCHAR(10)
)
go
INSERT INTO TimeTest
SELECT '2010910','0900','23'

UNION SELECT '2010910','1300','21'
UNION SELECT '2010910','2200','29'
UNION SELECT '2010911','1300 ','19'
UNION SELECT '2010911','2200','27'
UNION SELECT '2010912','1300','22'
UNION SELECT '2010912','1600','18'


SELECT * FROM TimeTest
WHERE  
CONVERT(DATETIME,LEFT(date,4)+'-'+LEFT(RIGHT(date,4),2)+'-'+RIGHT(date,2)+' '+ LEFT([TIME],2)+':'+RIGHT([TIME],2) )
BETWEEN '2010-9-10 13:00:00' and  '2010-9-11 23:00:00'
2010-09-20 23:01
btcj
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2006-3-24
收藏
得分:0 

感谢6楼的,经查询正确,
2楼和4楼都忽略了时间TIME每天都是重复的24个值,所以用and连接并不能查询到所要的结果。
2010-09-21 15:13
快速回复:再求高手SQL语句
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.026464 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved