SQL Server雨情处理自动补数据

在水利水雨情遥测数据的处理当中,一个ST_PPTN_R表中记录着各个站点在有降雨的情况下整点的累计雨量数据,而在没有降雨的情况下,是不往该表中写数据的。


在Android开发中,利用achartengine来绘制雨量柱状图的时候,要绘制时报、日报、月报,可以使用下面的语句进行

--时报
SELECT [TM],[DRP] FROM [ST_PPTN_R] WHERE STCD='62927600' AND TM>='2014-08-11 09:00' AND TM<='2014-08-12 08:00'  ORDER BY [TM];

--日报
SELECT convert(varchar(10),tm,120) [TM],sum([DRP]) drp FROM [ST_PPTN_R] WHERE STCD='62927600' AND TM>='2014-08-01' AND TM<='2014-08-31' group BY convert(varchar(10),tm,120);

--月报
SELECT convert(varchar(7),tm,120) [TM],sum([DRP]) drp FROM [ST_PPTN_R] WHERE STCD='62927600' AND TM>='2014-01-01' AND TM<='2014-12-31'  group BY convert(varchar(7),tm,120);
截图如下:


这样就存在一个问题,就是需要补时间,以下提供一种利用C#代码补非降雨时间:

if (context.Request.QueryString["cls"].ToString() == "sb")
{
     dt2 = FillNewDataTable(dm.ExecuteDataTable(ssql, ct, sqlP), "sb");
}
if (context.Request.QueryString["cls"].ToString() == "rb")
{
     dt2 = FillNewDataTable(dm.ExecuteDataTable(ssql, ct, sqlP), "rb");
}
if (context.Request.QueryString["cls"].ToString() == "yb")
{
     dt2 = FillNewDataTable(dm.ExecuteDataTable(ssql, ct, sqlP), "yb");
}

...

#region  对缺少的日期进行自动补值 
    
    public DataTable FillNewDataTable(DataTable dt,string type)
    {
        DataTable datatable = new DataTable();
        DataColumn dc = null;
        dc = datatable.Columns.Add("TM", Type.GetType("System.DateTime"));
        dc = datatable.Columns.Add("DRP", Type.GetType("System.Double"));
        switch (type)
        {
            case "sb":
                for (DateTime d = BEGIN; d <= END; d=d.AddHours(1))
                {
                    DataRow[] drv = dt.Select(" TM='" + d + "'");
                    if (drv.Length == 0)
                    {
                        DataRow dr = datatable.NewRow();
                        dr["TM"] = d;
                        dr["DRP"] = 0.0;
                        datatable.Rows.Add(dr);
                    }
                    else if (drv.Length == 1)
                    {
                        DataRow dr = datatable.NewRow();
                        dr["TM"] = d;
                        foreach (DataRow row in drv)
                        {
                            dr["DRP"] =row[1];
                        }
                        datatable.Rows.Add(dr); 
                    }
                }
                break;
            case "rb":
                for (DateTime d = BEGIN; d <= END; d = d.AddDays(1))
                {
                    DataRow[] drv = dt.Select(" TM='" + d.ToString("yyy-MM-dd") + "'");
                    if (drv.Length == 0)
                    {
                        DataRow dr = datatable.NewRow();
                        dr["TM"] = d;
                        dr["DRP"] = 0.0;
                        datatable.Rows.Add(dr);
                    }
                    else if (drv.Length == 1)
                    {
                        DataRow dr = datatable.NewRow();
                        dr["TM"] = d;
                        foreach (DataRow row in drv)
                        {
                            dr["DRP"] = row[1];
                        }
                        datatable.Rows.Add(dr);
                    }
                }
                break;
            case "yb":
                for (DateTime d = BEGIN; d <= END; d = d.AddMonths(1))
                {
                    DataRow[] drv = dt.Select(" TM='" + d.ToString("yyyy-MM") + "'");
                    if (drv.Length == 0)
                    {
                        DataRow dr = datatable.NewRow();
                        dr["TM"] = d;
                        dr["DRP"] = 0.0;
                        datatable.Rows.Add(dr);
                    }
                    else if (drv.Length == 1)
                    {
                        DataRow dr = datatable.NewRow();
                        dr["TM"] = d;
                        foreach (DataRow row in drv)
                        {
                            dr["DRP"] = row[1];
                        }
                        datatable.Rows.Add(dr);
                    }
                }
                break; 
        }
        return datatable;
    }
    
    #endregion
...


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值