版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
訪問WinCC歸檔數(shù)據(jù)庫的方法WinCC歸檔數(shù)據(jù)庫介紹WinCC的歷史工藝數(shù)據(jù)和報警消息保存在SQLServer數(shù)據(jù)庫,數(shù)據(jù)以分段和壓縮形式儲存,不方便直接通過SQL去讀取,用WinCCOLEDBProvider訪問這些數(shù)據(jù)時會自動合并分段并解壓縮數(shù)據(jù)。安裝ConnectivityPackWinCCOLEDBprovider由WinCC的ConnectivityPack選件提供,在安裝WinCC時需要安裝ConnectivityPack。在提供數(shù)據(jù)的WinCC的計算機需安裝ConnectivityPackserver,讀取數(shù)據(jù)的計算機上安裝ConnectivityPackclient,可以在計算機上同時安裝ConnectivityPackserver和ConnectivityPackclient。在SQLServer中通過鏈接服務器訪問歸檔數(shù)據(jù)庫創(chuàng)建鏈接服務器安裝了WinCC的計算機中,啟動WinCC項目時會自動創(chuàng)建鏈接服務器。在未安裝WinCC的計算機需要手動創(chuàng)建鏈接服務器。打開SQLServerManagementStudio,在對象資源管理器中,展開“服務器對象”,右鍵單擊“鏈接服務器”,然后單擊“新建鏈接服務器”。如下圖填入鏈接服務器信息,數(shù)據(jù)源(DataSource)中填入WinCC服務器的數(shù)據(jù)庫完整實例名,目錄(Catalog)中填入歸檔數(shù)據(jù)庫名。使用OPENQUERY查詢連接服務器查詢鏈接數(shù)據(jù)庫使用OPENQUERY,傳遞給OPENQUERY查詢語句不同于SQL,是WinCC的特定查詢語句,可通過變量ID或變量名查詢。如下:select
*from
openquery(LnkRtDb_WinCCOLEDB,'Tag:R,1,''0000-00-0001:00:00.000'',''0000-00-0000:00:00.000''')使用變量ID查詢:使用變量名查詢:在SQLServer中通過OPENDATASOURCE訪問歸檔數(shù)據(jù)庫通過OPENDATASOURCE()函數(shù)可直接查詢OLEDB數(shù)據(jù)源,語法如下:SELECT
*FROM
OPENDATASOURCE('WinCCOleDbProvider.1','Provider=WinCCOLEDBProviderforArchives;Catalog=CC_WinCCSer_19_02_14_10_59_03R;DataSource=WIN-54UD17PRU0N\WINCC').N'Tag:R,1,''0000-00-0000:10:00.000'',''0000-00-0000:00:00.000'''通過存儲過程訪問歸檔數(shù)據(jù)庫存儲過程(StoredProcedure)是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的SQL語句集,它存儲在數(shù)據(jù)庫中,一次編譯后永久有效,用戶通過指定存儲過程的名字并給出參數(shù)(如果該存儲過程帶有參數(shù))來執(zhí)行它。適用于WinCC歸檔數(shù)據(jù)庫的存儲過程有哪些如下圖的路徑,在SystemDatabases->master數(shù)據(jù)庫下有部分存儲過程,在WinCC項目程序對應的數(shù)據(jù)庫下也有部分存儲過程。
大部分存儲過程都找不到對應的使用說明,下面對已知的幾個存儲過程簡單介紹。cp_TagStatisticcp_TagStatistic是對過程值統(tǒng)計分析的存儲過程,它的使用方法在官方文檔中有描述。CC_SP_ReadTags是一個讀取過程值的存儲過程,查詢到的值會被存儲到一個臨時表中。在SQLServer中CC_SP_ReadTags源代碼是被加密的,從網絡上查到的源代碼如下,僅做參考:+ViewCodeCC_SP_ReadTags的參數(shù)說明如下:參數(shù)說明@List變量列表@TimeBegin查詢的起始時間@TimeEnd結束時間@WHEREClause過濾條件@ORDERBYClause排序@Timestep時間間隔(以秒計),格式為’TimeStep=60’@Aggregationmode匯總類型(定義時間間隔結果)@TempTable臨時表名稱,默認值為“TlgDataTmp”@SymDataSource建立鏈接服務器的數(shù)據(jù)源@SymCatalog建立鏈接服務器的數(shù)據(jù)目錄@LS_Name指定要使用的鏈接服務器語句示例:USE[CC_WinCCSer_19_02_14_10_59_03R]GOIFOBJECT_ID('tempdb..##TagsTempTable')is
not
NULLDROP
Table
##TagsTempTableDECLARE
@return_valueintEXEC
@return_value=[dbo].[CC_SP_ReadTags]@List=N'archive1\tag1;archive1\tag2',@TimeBegin=N'0000-00-0000:01:00',@TimeEnd=N'0000-00-0000:00:00',@WHEREClause=default,@ORDERBYClause=default,@Timestep=default,@Aggregationmode=default,@TempTable=N'##TagsTempTable',@SymDataSource=default,@SymCatalog=default,@LS_Name=N'LnkRtDb_WinCCOLEDB'SELECT
'ReturnValue'
=@return_valueGO重新排列數(shù)據(jù)
上面的示例圖片中查詢出的數(shù)據(jù)是以列的形式排序的,通過下面代碼可以把相同時間戳的數(shù)據(jù)放在同一行。1234567891011121314151617181920212223242526272829303132declare
@TimeBegindatetime=
'2020-09-0300:00:00.000';declare
@TimeEnddatetime=
'2020-09-0400:00:00.000';declare
@TimeStepnvarchar(64)=
'10'Declare
@List
Varchar(1000)=N'SysInfo\CPU_1;SysInfo\CPU_2;SysInfo\CPU_3;SysInfo\CPU_4'declare
@strTimeBeginnvarchar(64)=format(Dateadd(hh,DATEDIFF(hh,GETDATE(),GETUTCDATE()),@TimeBegin),'yyyy-MM-ddHH:mm:ss.fff')declare
@strTimeEndnvarchar(64)=format(Dateadd(hh,DATEDIFF(hh,GETDATE(),GETUTCDATE()),@TimeEnd),'yyyy-MM-ddHH:mm:ss.fff')declare
@strTimeStepnvarchar(500)if@TimeStep<>''
set
@strTimeStep=N',''''TimeStep='
+@TimeStep+',1'''''else
set
@strTimeStep=
''declare
@temp
table(
ValueID
bigint,
TimeStamp
datetime,
RealValue
float,
Quality
int,
Flags
int)declare
@SQLnvarchar(1000)set
@SQL=
'select*fromopenquery(LnkRtDb_WinCCOLEDB,''Tag:R,('+@List+'),
'''''+@strTimeBegin+''''','''''+@strTimeEnd+''''''
+@strTimeStep+
''')'insert
into
@temp
exec(@SQL)SELECT
Dateadd(hh,DATEDIFF(hh,GETUTCDATE(),GETDATE()),[TimeStamp])
AS
TimeStamp,[1]
AS
CPU_1,[2]
AS
CPU_2,[3]
AS
CPU_3,[4]
AS
CPU_4From(SELECT
[ValueID],[TimeStamp],[RealValue]
from
@temp
)
AS
SourceTablePIVOT(max(Realvalue)
for
ValueID
in
([1],[2],[3],[4]))
AS
PivotTableorder
by
PivotTable.TimeStamp用VB腳本訪問歸檔數(shù)據(jù)庫創(chuàng)建數(shù)據(jù)庫連接
12345dimconnSet
conn=CreateObject('ADODB.Connection')conn.ConnectionString=
'Provider=WinCCOLEDBProvider.1;Catalog=CC_OpenArch_03_05_27_14_11_46R;DataSource=.\WinCC'conn.CursorLocation=3conn.open查詢數(shù)據(jù)庫
1234Dim
rs,SqlSet
rs=CreateObject('ADODB.Recordset')Sql=
'Tag:R,1,''0000-00-0000:10:00.000'',''0000-00-0000:00:00.000'''rs.OpenSql,conn,1,3訪問另一臺電腦的WinCC歸檔數(shù)據(jù)庫假如有兩臺電腦,命名為A和B,A和B電腦上都安裝了ConnectivityPack,從A電腦上通過WinCCOleDbProvider.1去訪問B電腦中的WinCC歸檔數(shù)據(jù)庫,需要按照如下做法:B
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 企業(yè)對企業(yè)管理咨詢項目合同
- 可穿戴設備產品研發(fā)生產協(xié)議
- 牛糞購銷合同
- 增強現(xiàn)實技術項目投資協(xié)議
- 吊裝承包合同
- 文化創(chuàng)意產業(yè)資源整合協(xié)議
- 智能財務管理系統(tǒng)開發(fā)及運營合作協(xié)議
- 買車銷售合同
- 清潔能源運營合作框架協(xié)議
- 紡織服裝設計生產合作協(xié)議
- 2025江蘇南京市金陵飯店股份限公司招聘高頻重點提升(共500題)附帶答案詳解
- 公共政策分析 課件匯 陳振明 第0-9章 導論、緒論:政策科學的“研究綱領”- 政策監(jiān)控
- 《藥品招商營銷概論》課件
- 2025年牛津譯林版英語七年級下冊全冊單元重點知識點與語法匯編
- 《小學作文指導》課件
- 2025年病案編碼員資格證試題庫(含答案)
- 2025新譯林版英語七年級下單詞表
- 新疆2024年中考數(shù)學試卷(含答案)
- 魏寧海超買超賣指標公式
- 2024-2030年中國連續(xù)性腎臟替代治療(CRRT)行業(yè)市場發(fā)展趨勢與前景展望戰(zhàn)略分析報告
- 跨學科主題學習:實施策略、設計要素與評價方式(附案例)
評論
0/150
提交評論