不是查询总数,我需要查询两个字段,使用convert函数按时间查询再分组,就得将两个字段放入分组条件中,就错乱了。
假设有表table,字段有时间精确到秒,ID,消费金额和消费地点,现在要查询一段时间每天的消费金额和地点(时间可随意指定)
sqlserver查询本周每天数据
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- 若邪 2015-10-20 08:23关注
围绕convert函数进行时间的筛选,还是可以的但是效率不高,
select c.autoid,c.callerid,c.doorid,c.cardday,c.eventtype,d.doorid as max_doorId,d.eventType as max_eventSort,d.cardday as max_cardDay
from(select * from cr_cardevent a
WHERE EXISTS (SELECT 1
FROM(
SELECT convert(varchar(10),cardday,121) as td, MIN(cardday)min_time,callerid FROM cr_cardevent c,Com_EmpCard card
Where cardday between '2014-09-01' and '2014-09-03' and c.cardid=card.cardid and card.cardid in
(select fingure.cardid from Finger_Data fingure) GROUP BY convert(varchar(10),cardday,121), callerid)b
WHERE a.cardday=b.min_time AND a.callerid=b.callerid ))c ,
(select *
from cr_cardevent a WHERE EXISTS (SELECT 1
FROM(SELECT convert(varchar(10),cardday,121) as td, MAX(cardday)max_time,callerid FROM cr_cardevent c,Com_EmpCard card
where cardday between '2014-09-01' and '2014-09-03' and c.cardid=card.cardid and card.cardid in
(select fingure.cardid from Finger_Data fingure) GROUP BY convert(varchar(10),cardday,121), callerid)b
WHERE a.cardday=b.max_time AND a.callerid=b.callerid))d,
cr_caller_basicinfo e
where c.callerid = d.callerid and c.callerid = e.callerid and e.callertype=1
and convert(varchar(10),c.cardday,121)=convert(varchar(10),d.cardday,121)
需求是一段时间内每天每个用户最大最小的两笔数据本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 python怎么在已有视频文件后添加新帧
- ¥20 虚幻UE引擎如何让多个同一个蓝图的NPC执行一样的动画,
- ¥15 fluent里模拟降膜反应的UDF编写
- ¥15 MYSQL 多表拼接link
- ¥15 关于某款2.13寸墨水屏的问题
- ¥15 obsidian的中文层级自动编号
- ¥15 同一个网口一个电脑连接有网,另一个电脑连接没网
- ¥15 神经网络模型一直不能上GPU
- ¥15 pyqt怎么把滑块和输入框相互绑定,求解决!
- ¥20 wpf datagrid单元闪烁效果失灵