亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

在SQL server數據存取過程中跳過非必要時間類型

添加時間:2014-3-24 17:22:28  添加: 思海網絡 
也許發現其實在申報的程序數據報告時,大部分都是以天為單位的,有些可能是用小時為單位。但是通常采取的方式都是直接調用T-SQL的時間函數比如DataAdd和DataPart。

  這種方式并不能讓人滿意,這樣會向SQl Server中加載許多沒用的信息。數據庫中呈現的應該是我們真正需要的干凈而簡潔的信息。有什么辦法來處理這一問題嗎?

  其實,可以借鑒Unix和PHP社區關于存取數據的處理方式。Unix的紀元是從1970年1月1日開始的。如果采取按秒計算的方式,在無符號的32位整數下,可以記錄136年。但是如果按分鐘計算,就是8100年。如果只是按天來計算那就差一點到12萬年了。

  所以,最好參照算術的方式來控制這一問題。比如按天來統計每個人的信息。

insert into DailyHits (UserId, DaysSince, Count)
select UserId, SecondsSince/86400, count(*)
  
from Hits
  
group by UserId, SecondsSince/86400
--86400 is the number of seconds in a day

insert into HourlyHits (UserId, HoursSince, Count)
select UserId, SecondsSince/3600, count(*)
  
from Hits
  
group by UserId, SecondsSince/3600
--3600 is the number of seconds in a hour

 

  同樣適用于在C#下對于相對時間參數的控制。

public static readonly DateTime Epoch = new DateTime(1970, 1, 1);
public IList GetDailyHits(DateTime from, DateTime to)
{

   command.CommandText
= "select * from DailyHits where DaysSince > @From and DaysSince < @To";
   command.Parameters.Add(
"@From", from.Substract(Epoch).TotalDays);
   command.Parameters.Add(
"@To", to.Substract(Epoch).TotalDays);
   ...
}

 

  以上所舉的例子只是給出了簡化的代碼,但是所有重要的信息都已經包含在內了。這種方式不僅僅提供了很好的存儲工作方式,最重要的是其完全獨立于基礎數據庫。

關鍵字:數據庫、SQL server

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站