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
...
相關文章
- SQL Server 資料庫查詢死鎖的處理步驟SQLServer資料庫
- SQL SERVER 2012資料庫自動備份的方法SQLServer資料庫
- Python自動化處理Excel資料PythonExcel
- 不care工具,在大資料平臺中Hive能自動處理SQL大資料HiveSQL
- sql server對於日期的處理SQLServer
- SQL Server 異常程式碼處理SQLServer
- SQL Server2008程式堵塞處理方法SQLServer
- SQL server 特殊字元"u0000"處理SQLServer字元
- Sql Server資料庫類似正規表示式的字元處理問題SQLServer資料庫字元
- SQL Server實戰二:建立、修改、複製、刪除資料庫表並加以資料處理SQLServer資料庫
- SQL Server資料庫恢復,SQL Server資料恢復,SQL Server資料誤刪除恢復工具SQLRescueSQLServer資料庫資料恢復
- MySQL資料庫自動補全命令MySql資料庫
- python遍歷迭代器自動鏈式處理資料Python
- 在 SQL Server 中使用 Try Catch 處理異常SQLServer
- SQL Server 2008事件處理系統簡介LSSQLServer事件
- SQL Server映象自動生成指令碼方法SQLServer指令碼
- SQL server 修改表資料SQLServer
- 資料庫映象 (SQL Server)資料庫SQLServer
- SQL Server資料庫安全SQLServer資料庫
- 【Python自動化Excel】pandas處理Excel資料的基本流程PythonExcel
- 聲網崩潰資料的自動化閉環處理
- sql server編寫archive通用模板指令碼實現自動分批刪除資料SQLServerHive指令碼
- Blazor使用sql server 資料庫BlazorSQLServer資料庫
- SQL Server資料庫巡檢SQLServer資料庫
- sql server 2005資料庫快照SQLServer資料庫
- SQL Server收縮資料庫SQLServer資料庫
- sql server 資料庫收縮SQLServer資料庫
- SQL Server資料庫遷移SQLServer資料庫
- SQL Server-資料型別SQLServer資料型別
- 管理SQL Server資料庫安全SQLServer資料庫
- 介面自動化測試:apiAutoTest使用re 處理資料依賴API
- Python資料處理(二):處理 Excel 資料PythonExcel
- 因為修改windows管理員密碼導致sql server 2005不能啟動處理Windows密碼SQLServer
- 機器學習 第3篇:資料預處理(使用插補法處理缺失值)機器學習
- ChatExcel--自動處理表格Excel
- 介面自動化測試-apiAutoTest 優化之資料依賴處理API優化
- Python自動化測試-使用Pandas來高效處理測試資料Python
- Excel檔案 利用MySQL/Python 實現自動處理資料的功能ExcelMySqlPython
- SQL Server 2014 匯出資料字典SQLServer