訪問WinCC歸檔數(shù)據(jù)庫的方法_第1頁
訪問WinCC歸檔數(shù)據(jù)庫的方法_第2頁
訪問WinCC歸檔數(shù)據(jù)庫的方法_第3頁
訪問WinCC歸檔數(shù)據(jù)庫的方法_第4頁
訪問WinCC歸檔數(shù)據(jù)庫的方法_第5頁
已閱讀5頁,還剩10頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

訪問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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論