小菜来袭 2017-01-19 13:10 采纳率: 40%
浏览 1282
已采纳

c# 数据库问题 取出字段的值 并做判断

 DECLARE @SQL VARCHAR(8000)
SET @SQL='SELECT CONVERT(VARCHAR(10),DacTime,120)'
DECLARE @INDEX INT
SET @INDEX=1
WHILE @INDEX<=24
BEGIN
    SET @SQL=@SQL+',SUM(CASE WHEN DATEPART(HH,DacTime)='+CAST(@INDEX AS VARCHAR(2))+' THEN 1 END)['+CAST(@INDEX AS VARCHAR(2))+']'
    SET @INDEX=@INDEX+1
END
SET @SQL=@SQL+'FROM [SURF_DeviceDataHist] where DateDiff(dd,DacTime,getdate())=1  GROUP BY CONVERT(VARCHAR(10),DacTime,120)'
EXEC(@SQL)

下面是查询结果
图片说明

我想取消那个无列名的显示
然后把1到24每个字段数据取出来 判断是不是等于3

  • 写回答

1条回答 默认 最新

  • threenewbee 2017-01-19 18:49
    关注

    CONVERT(VARCHAR(10),DacTime,120)
    去掉这个就没有第一列了
    @INDEX 就是所有为1的数据的和

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已采纳回答 9月15日

悬赏问题

  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了