主頁 > 資料庫 > 關于統計

關于統計

2020-09-23 14:01:50 資料庫

我現在有這樣一個任務,就是統計每小時呼損和接通的數量,兩個資料表單
比如:
時間   數量    時間   數量
0      15        0      13
1      100       1      89 
2      50        1      45
。。。
最后得出來的結論是用前邊表中的數量減去后邊表中的數量,再形成一張新表用來記錄每個時間段呼損的數量。這樣的結果應該如何撰寫。請高手指教,謝謝!

uj5u.com熱心網友回復:

假設你的資料視窗是有規律的,那就好辦。比如前者先得到資料,后者后得到資料。
那么就在后者中寫一個事件,計算之后插入表中就好了。

uj5u.com熱心網友回復:

是有規律的就是從0點到23點,要是但是哪個事件能在資料檢索后就可以將結果統計并插入新資料視窗中呢?

uj5u.com熱心網友回復:

如果不是你的程式直接接受的,二是其他設備接收,并插入到資料庫的。
建議使用觸發器。

uj5u.com熱心網友回復:

時間   數量    時間   數量
0      15        0      13
1      100       1      89 
2      50        1      45

select a.時間 , a.數量 - isnull(b.數量,0) 數量 from tb1 a
left join
(select 時間,sum(數量) 數量 from t2 group by 時間) b
on a.時間 = b.時間

然后用動態DW實作.

uj5u.com熱心網友回復:

動態創建資料視窗 
 
  在實際應用中,經常需要根據用戶需求來動態創建資料窗,一般方法是這樣的。
  在一個window中加入一個資料窗控制元件,如dw_new,但是該資料窗沒有data object,(空白的)就可以用以下語法來創建:
  dw_new.create(ls_syntax,ls_error) // 創建語法,錯誤資訊
  ls_syntax可以用以下三種方法來形成:

  一、動態由sql語法創建:
  // 連接到pb的example資料庫
  string ls_sql,ls_syntax,ls_error
  ls_syntax = 'select * from department'
  ls_syntax = sqlca.SyntaxFromSQL(ls_sql,'style(type=grid)',ls_error)
  if len(ls_error) >0 then
   messagebox('Error','SyntaxFromSQL Error:~r'+ls_error)
  else
   dw_new.create(ls_syntax,ls_error)
   if len(ls_error) >0 then
    MessageBox("Error", "Create have these errors: ~r" + ls_error)
   else
    dw_new.settransobject(sqlca)
    dw_new.retrieve()
   end if
  end if

  二、由另一個資料窗的syntax來創建
  string ls_syntax,ls_error
  ls_syntax = dw_test.describe('datawindow.syntax')
  dw_new.create(ls_syntax,ls_error)
  if ls_error <> '' then
   messagebox('Create Error',ls_error)
  else
   dw_new.settransobject(sqlca)
   dw_new.retrieve()
  end if

  三、讀取psr檔案來創建
  string ls_syntax,ls_error,ls_ret
  ls_ret = char(13)+char(10) //回車鍵
  int li_fileNum
  long li_length
  li_FileNum = FileOpen("efef.psr",Streammode!, read!, shared!, Replace!)

  if li_filenum >0 then
   FileSeek(li_FileNum, 158, FromBeginning!)
   li_length = fileRead(li_filenum,ls_syntax)
  end if
  fileclose(li_filenum)
  if li_length = 0 then return
  ls_syntax = "release 5;"+ls_ret+ls_syntax 

  //截掉ls_syntax中的資料部分,5.0以"sparse(names="dept_name?) "作為參考位置
  //6.0以html(作為參考位置
  long pos1,pos2
  pos1 = pos(ls_syntax,'sparse(names="',1)
  pos2 = pos(ls_syntax,'"',pos1 +16)
  ls_syntax = left(ls_syntax,pos1) + mid(ls_syntax,pos1 +1,pos2 - pos1 +1)
  dw_New.create(ls_syntax,ls_error)
  if ls_error <> '' then
   messagebox('Create Error',ls_error)
  else
   dw_new.settransobject(sqlca)
   dw_new.retrieve()
  end if
  //pb6,pb7的代碼可以參照pb5自己寫,只是檔案頭和資料窗結束標記不同而已。
 

uj5u.com熱心網友回復:

PowerBuilder用Create()函式創建動態資料視窗,其語法格式為:dw.Create(Syntax[,ErrString]) 
  其中:dw為需創建的動態資料視窗名;Syntax為創建動態資料視窗的語法字串;ErrString為可選引數,用來存放發生錯誤時的錯誤資訊,若忽
略,發生錯誤時系統自動顯示訊息框,一般不符我們需要,所以需定義該引數。

  顯然重點在Syntax, PowerBuilder提供LibraryExport()與SyntaxFromSQL()二個函式來達到這個目的:

  一、 LibraryExport()函式
  功能:從PowerBuilder庫中輸出一個物件,回傳該物件的語法。
  語法格式:LibraryExport(LibName,ObjName,ObjType) 
  其中:LibName 為帶路徑的PowerBuilder庫名,若未指定路徑,則按系統標準搜索路徑搜索;ObjName為匯出物件名,現為LibName中的資料視窗
物件名;ObjType為該物件的型別,現為資料視窗,值為ExportDataWindow!。示例如下:
  String ls_DwSyntax,ls_Error
  ls_DwSyntax=LibraryExport("C:\PBExam\dy_dw.pbl","d_tbl1", ExportDataWindow!)
  //資料視窗dw_1的產生下面將詳細討論,現暫略
  dw_1.Create(ls_DwSyntax,ls_Error)
  //以下陳述句與下面示例中的相同,故此處略。 
  LibraryExport()函式是利用已有的資料視窗物件創建動態資料視窗,有一定的使用價值,但不多見。 

  二、 SyntaxFromSQL()函式
  功能:基于SQL的SELECT 陳述句產生創建資料視窗的語法。
  語法格式:Transaction.SyntaxFromSQL(SqlString,StyleString,ErrorString)
  其中:Transaction.為已連接的事務物件,一般即為SQLCA;SqlString為SQL--SELECT 陳述句;Stylestring為資料視窗的顯示風格字串,比較復
雜,一般常用"Style(Type=Grid)";ErrorString用來存放發生錯誤時的錯誤資訊。
  一般來說,SyntaxFromSQL()函式靈活性高、功能強,因此創建動態資料視窗大都使用該函式,下面的示例也是使用該函式。

  三、創建動態資料視窗的一般步驟
  創建動態資料視窗的一般步驟如下:
  1、在某視窗(如w_main)上用滑鼠點建一個資料視窗控制元件(如dw_1),其DataObject為空。
  2、構造SyntaxFromSQL()函式的語法字串。這是PowerBuilder動態資料視窗的關鍵,稍為復雜一些,具體做法請見下面實體。
  3、用Create()函式創建動態資料視窗dw_1,并用SetTransObject()函式為其分配事務物件,具體做法請見下面實體。
  這種方法的主要缺點是必須在設計階段先建資料視窗控制元件,運行時無法增減,這對于一些較為特殊的應用(如設計階段尚不知需幾個資料視窗)
就不太適合了。那如何解決這個問題呢?經過一番摸索并查閱了一些資料,終于找到了二種解決方法,現分別介紹如下:   1、創建一個標準可視資料視窗用戶物件u_d_sample
  PowerBuilder6.0/6.5中步驟為:點擊工具列上的UserObject圖示,在彈出的Select User Object視窗中點擊New按鈕,出現New User Object視窗,雙擊其中Visual下的Standard圖示, 在彈出的Select Standard Visual Type視窗中雙擊datawindow選項,即出現User Object(Untitled)視窗,點擊工具列上的Save圖示,彈出的Save User Object視窗,在User Objects: 中輸入u_d_sample回車即進入User Object---u_d_sample視窗,關閉該視窗,標準可視資料視窗用戶物件u_d_sample即告建成。

  PowerBuilder7.0中步驟為:點擊工具列上的New圖示,在彈出的New視窗中選擇Object頁面,雙擊其中的Standard Visual圖示, 在彈出的Select Standard Visual Type視窗中雙擊datawindow選項,出現User Object(Untitled)inherited from datawindow視窗,將其右邊的Title欄中的none洗掉,再點擊左邊空白區,然后點擊工具列上的Save圖示,以后的操作步驟與PowerBuilder6.0/6.5大致相同。至于PowerBuilder8.0則與PowerBuilder7.0大體相同,不再贅述。

  2、直接定義DataWindow型變數dw_1如下:
  DataWindow dw_1
  dw_1=Create DataWindow 
  其實第1種方法還須定義dw_1,形式如下:
  u_d_sample dw_1
  dw_1=Create u_d_ sample //此句可省略 
  這二種方法的關鍵都是使用OpenUserObject()函式,其功能即為打開一個用戶物件,語法格式:w_name.OpenUserObject(ObjName[,x,y]) 其中ObjName為需打開的用戶物件名;x、y為用戶物件的打開位置,省略時值均為0。
  下面請見具體實體, 該實體在Win98、PowerBuilder8.0/PowerBuilder7.0/PowerBuilder6.5下通過,ODBC資料源已配置,為FoxPro25(可根據需要使用其他資料庫),資料表為bb.dbf。請先建視窗w_main,在其Open事件中寫入以下代碼:(注意:PowerBuilder8.0中先須創建WorkSpace(*.pbw),其他操作基本同PowerBuilder7.0)

  //動態資料視窗dw_1創建實體
  string lserr,lsSQLstr,lsDWsyntax,lserrC
  SQLCA.DBMS="ODBC"
  SQLCA.DBParm="ConnectString='DSN=FoxPro25'" //本例使用FoxPro25資料庫,可根據需要用其他資料庫
  Connect;
  //下面3條陳述句即為關鍵,若dw_1為滑鼠點建請洗掉這3條陳述句,否則會出錯。
  DataWindow dw_1 //若采用資料視窗用戶物件u_d_sample,則可改為:u_d_sample dw_1
  dw_1=Create DataWindow //若采用資料視窗用戶物件u_d_sample,此句應去除。
  OpenUserObject(dw_1) 
  //Select…As…的As可將列標題顯示為As之后的字符,較為靈活方便。
  //可根據實際情況設計生成Select陳述句及Where子句的可視化界面
  lsSQLstr="Select A12 As 主管部門,A01 As 法人代碼,mc As 企業名稱,A06 From bb Where A12<'1'"
  lsDwsyntax=SQLCA.SyntaxFromSQL(lsSQLstr,"style(type=Grid)",lserr) //構造SyntaxFromSQL()函式
  If Len(lserr)>0 Then
   //如果構造SyntaxFromSQL()函式失敗,則顯示錯誤資訊并退出
   messagebox("錯誤資訊!",lserr)
   Return
  end if
  dw_1.Create(lsDwsyntax,lserrC) //創建動態資料視窗dw_1
  If Len(lserrC)>0 Then
   //如果創建動態資料視窗dw_1失敗,則顯示錯誤資訊并退出
   messagebox("錯誤資訊!",lserrC)
   Return
  end if
  //以下設定dw_1的一些屬性,可根據實際需要設定。
  dw_1.X=5
  dw_1.Y=5
  dw_1.width=1500
  dw_1.height=650
  dw_1.Visible=True
  dw_1.Enabled=True
  dw_1.HScrollBar=True
  dw_1.VScrollBar=True
  //為dw_1分配事務物件SQLCA
  dw_1.SetTransObject(SQLCA)
  //提取資料
  dw_1.Retrieve() 

  第2種方法的優點大家一看即知,不必費勁去創建一個標準可視資料視窗用戶物件,但存在不足之處:不能在視窗w_main的其他事件或控制元件中參考dw_1。解決方法很簡單:將dw_1定義為實體變數(Instance Variable)。PowerBuilder6.0/6.5中:在視窗畫筆(w_main)的選單上點擊Declareà Instance Variables…,在彈出視窗Declare Instance Variables中輸入datawindow dw_1, 點擊Ok按鈕即告完成。PowerBuilder7.0/8.0中:打開視窗畫筆,在其下半部的視窗Declare Instance Variables中輸入datawindow dw_1, 點擊工具列上的Save圖示即告完成。 

uj5u.com熱心網友回復:

都是很好的建議! 值得學習

uj5u.com熱心網友回復:

都是很好的建議! 值得學習

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/112145.html

標籤:數據庫相關

上一篇:推薦一個網格式分布式資料庫中間件給大家

下一篇:急!!pb+myodbc的問題

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more