詳解基于Labwindows/CVI的測試系統(tǒng)數據庫設計
數據庫實際上就是存儲數據的“倉庫”。但數據不是存放在容器或空間中,而是存放在計算機的外存儲器上(如磁盤),并且是有組織的存放。數據的管理和利用通常是通過計算機的數據管理軟件——數據庫管理系統(tǒng)來完成的。因此,數據庫不單是指存有數據的計算機外存,而是指存放在外存上的數據集合及其管理軟件的總和,通常稱為數據庫系統(tǒng)。
LabWindows/CVI是一種C語言開發(fā)系統(tǒng)。與其它開發(fā)系統(tǒng)相比,CVI增添了一個交互式程序開發(fā)環(huán)境、數據采集函數庫、儀器控制工具等工具。同時,LabWindows/CVI包含一整套用來進行數據采集、分析、顯示等處理的軟件工具??梢岳肅VI的交互式環(huán)境編寫調試ANSI C語言(美國國家標準C語言),還可以使用LabWindows/CVI自帶的庫函數以及調用其它的C語言模塊、動態(tài)鏈接庫函數、C語言庫函數、儀器驅動程序等。CVI最大的優(yōu)勢在于具有功能強的的函數庫。它的函數庫包含了對數據處理的每一過程及儀器進行控制的各種函數。
一般情況下,數據庫都有強大的數據存儲和管理能力以及實際的功能需求,因此,我們在很多數據處理中都要應用數據庫技術。本文采用的LabWindows/CVI SQL工具包符合ODBC標準,可作為驅動,并配合Microsoft Access2000作為數據庫進行配置,可以很好地實現數據庫技術在一般測試系統(tǒng)中的應用,從而極大提高測試系統(tǒng)數據的管理效率。
1 SQL簡介
SQL是STructure Query Language的縮寫,意思為結構化查詢語言。利用SQL可實現對數據庫的各種交互操作。根據美國國家標準研究所ANSI( American National Standards InsTItute)的聲明,SQL是關系型數據庫管理系統(tǒng)的標準語言。利用相應的SQL語句可實現數據庫的數據更新、數據獲取等功能。
2 測試系統(tǒng)數據庫的配置
在測試系統(tǒng)中,數據庫中的數據表主要由幾大塊組成。測試參數數據的存儲與處理,這一塊是本測試系統(tǒng)數據庫設計的核心,包括實際測試結果數據的存儲。為了存儲的方便,應當精心設計各個用戶參數、測試項判據和測試結果的數據邏輯設計結構如圖1所示。
本文所用的數據庫的配置有以下幾個步驟:
(1)數據庫系統(tǒng)的注冊及數據源添加
開放數據庫互連(ODBC)標準取決于訪問每個數據庫系統(tǒng)的ODBC驅動器,配置時必須對任何使用的ODBC驅動器進行注冊。以便在win-dows2000系統(tǒng)的控制面板上的ODBC選項里進行配置和添加。
(2)數據庫連接
執(zhí)行SQL語句前,必須建立數據庫連接。這一步以SQL Toolkit為中介,可以用程序方式來實現連接。
(3)激活SQL連接
事實上,激活SQL連接是進行查詢會話的前提,可以采用自動SQL或顯式SQL兩種方式來實現SQL旌接的激活。
(4)處理SQL語句
這是操作數據庫的關鍵。主要是對數據庫創(chuàng)建記錄、獲取記錄、更新記錄、刪除記錄等。通過使用SELECT語句可將數據表中的字段綁定到程序中的變量上,接著用取值函數獲取所選記錄。
(5)斷開SQL璉接
SQL操作結束后,應斷開SQL連接,這一步驟在任何方向上取值時都是特別重要的,它可以保證關閉連接并刪除建立連接時所生成的臨時登記文件。
(6)斷開數據庫
全部數據庫操作結束后,應確保斷開通過SQL建立的數據庫連接已被其他地方不小心修改,同時也可用來釋放系統(tǒng)資源。
3 測試系統(tǒng)數據的代碼設計
現以本測試系統(tǒng)中的用戶管理數據的獲取為例,詳細介紹本系統(tǒng)數據庫的設計方法,其部分配置代碼如下:
//激活SQL連接
hstmt=DBActivateMap(hmap,"Pass-Word");
//操作SQL并使得當前各字段分別映射到各相關變量
resCode=DBFetchRandom(hstmt,userid2+1);
//其他操作
//斷開SQL連接
resCode=DBDeactivateMap Oamap);
//斷開數據庫
resCode=DBDiscONnect(hdbc);
本文介紹了基于Labwindows的測試系統(tǒng)軟件數據庫的設計和配置方法。目前,這部分技術已經相當成熟,將其運用到虛擬儀器系統(tǒng)中,可以更好的管理系統(tǒng)數據,提高系統(tǒng)效率。