昨天小編分享兩篇關於遊標的文章:遊標指令碼效能問題詳解之案例實踐篇,遊標指令碼效能問題詳解之遊標分類特點篇 ,並在文章中簡單對遊標做了說明。今天小編找到了一篇具體介紹遊標的博文,在這裡與大家一起學習。
遊標cursor)
遊標是系統為使用者開設的一個資料緩衝區,存放SQL語句的執行結果。每個遊標區都有一個名字。使用者可以用SQL語句逐一從遊標中擷取記錄,並賦給主變數,交由主語言進一步處理。主語言是面向記錄的,一組主變數一次只能存放一條記錄。僅使用主變數並不能完全滿足SQL語句嚮應用程式輸出資料的要求。嵌入式SQL引入了遊標的概念,用來協調這兩種不同的處理方式。
在資料庫開發過程中,當你檢索的資料只是一條記錄時,你所編寫的事務語句代碼往往使用SELECT INSERT 語句。但是我們常常會遇到這樣情況,即從某一結果集中逐一地讀取一條記錄。那麼如何解決這種問題呢?遊標為我們提供了一種極為優秀的解決方案。
1.遊標和遊標的優點
在資料庫中,遊標是一個十分重要的概念。遊標提供了一種對從表中檢索出的資料進行操作的靈活手段,就本質而言,遊標實際上是一種能從包括多條資料記錄的結果集中每次提取一條記錄的機制。遊標總是與一條SQL 選擇語句相關聯因為遊標由結果集可以是零條、一條或由相關的選擇語句檢索出的多條記錄)和結果集中指向特定記錄的遊標位置群組成。當決定對結果集進行處理時,必須聲明一個指向該結果集的遊標。如果曾經用 C 語言寫過對檔案進行處理的程式,那麼遊標就像您開啟檔案所得到的檔案控制代碼一樣,只要檔案開啟成功,該檔案控制代碼就可代表該檔案。對於遊標而言,其道理是相同的。可見遊標能夠實現按與傳統程式讀取一般檔案類似的方式處理來自基礎資料表的結果集,從而把表中資料以一般檔案的形式呈現給程式。
我們知道關聯式資料庫管理系統實質是面向集合的,在MS SQL SERVER 中並沒有一種描述表中單一記錄的表達形式,除非使用where 子句來限制只有一條記錄被選中。因此我們必須藉助於遊標來進行面向單條記錄的資料處理。由此可見,遊標允許應用程式對查詢語句select 返回的行結果集中每一行進行相同或不同的操作,而不是一次對整個結果集進行同一種操作;它還提供對基於遊標位置而對錶中資料進行刪除或更新的能力;而且,正是遊標把作為面向集合的資料庫管理系統和面向行的程式設計兩者聯絡起來,使兩個資料處理方式能夠進行溝通。
2. 遊標種類
MS SQL SERVER 支援三種類型的遊標:Transact_SQL 遊標,API 伺服器資料指標和客戶遊標。
1) Transact_SQL 遊標
Transact_SQL 遊標是由DECLARE CURSOR 文法定義、主要用在Transact_SQL 指令碼、預存程序和觸發器中。Transact_SQL 遊標主要用在伺服器上,由從用戶端發送給伺服器的Transact_SQL 陳述式或是批處理、預存程序、觸發器中的Transact_SQL 進行管理。 Transact_SQL 遊標不支援提取資料區塊或多行資料。
2) API 遊標
API 遊標支援在OLE DB, ODBC 以及DB_library 中使用遊標函數,主要用在伺服器上。每一次用戶端應用程式調用API 遊標函數,MS SQL SEVER 的OLE DB 提供者、ODBC磁碟機或DB_library 的動態連結程式庫DLL) 都會將這些客戶請求傳送給伺服器以對API遊標進行處理。
3) 客戶遊標
客戶遊標主要是當在客戶機上緩衝結果集時才使用。在客戶遊標中,有一個預設的結果集被用來在客戶機上緩衝整個結果集。客戶遊標僅支援靜態資料指標而非動態資料指標。由於伺服器資料指標並不支援所有的Transact-SQL 陳述式或批處理,所以客戶遊標常常僅被用作伺服器資料指標的輔助。因為在一般情況下,伺服器資料指標能支援絕大多數的遊標操作。由於API 遊標和Transact-SQL 遊標使用在伺服器端,所以被稱為伺服器資料指標,也被稱為後台遊標,而用戶端資料指標被稱為前台遊標。在本章中我們主要講述伺服器後台)遊標
遊標詳細說明:
RS.OPEN SQL,CONN,A,B
參數A為設定遊標的類型,其取值為:
0 僅向前遊標,只能向前瀏覽記錄,不支援分頁、Recordset、BookMark
1 鍵集遊標,其他使用者對記錄說做的修改將反映到記錄集中,但其他使用者增加或刪除記錄不會反映到記錄集中。支援分頁、Recordset、BookMark
2 動態資料指標功能最強,但耗資源也最多。使用者對記錄說做的修改,增加或刪除記錄都將反映到記錄集中。支援全功能瀏覽。
3 靜態資料指標,只是資料的一個快照,使用者對記錄說做的修改,增加或刪除記錄都不會反映到記錄集中。支援向前或向後移動。
參數B為記錄集的鎖定類型,其取值為:
1 鎖定類型,預設的,唯讀,不能作任何修改
2 當編輯時立即鎖定記錄,最安全的方式
3 只有在調用Update方法時才鎖定記錄集,而在此前的其他動作仍可對目前記錄變更、插入和刪除等
4 當編輯時記錄不會被鎖定,而更改、插入和刪除是在批處理方式下完成的
開啟資料記錄集方法其實不止一種,但是我們用的最多的就是
rs.open sql,1,1的方法,可是後面的數字參數很多人不解其意,下面我們來介紹一下。
其實open方法後面有多個參數
CursorType LockType CommandType
比如 rs.open sql,1,1
也可以寫成
rs.cursorType = 1
rs.LockType = 1
rs.open sql
其中CursorType代表從一個表或者一個SQL查詢結果返回的記錄。
這個參數有四個值分別是:
adOpenForwardOnly 表示只允許在記錄集內的記錄間往前移動。這個是預設值。
adOpenKeyset 反映由其它使用者所做的對記錄的改變或者刪除動作,但並不反映由其它使用者做作的添加新記錄的動作。
adOpenDynamic 反映由其它使用者所做的對記錄的改變或者刪除動作,包括添加的新記錄
adOpenStatic 不反映其它使用者對記錄所做的修改,添加,刪除動作。
這四個值VBSCRIPT預定義位
adOpenForwardOnly = 0
adOpenKeyset = 1
adOpenDynamic = 2
adOpenStatic = 3
lockType 表示當開啟記錄集時,資料提供者用於鎖定資料庫的類型:
adLockReadOnly 資料不能改變,這是預設值!
adLockPessimistic 資料提供者在開始編輯資料的時候鎖定記錄
adLockOptimistic 僅當調用update方法時,資料提供者鎖定記錄
adLockBatchOptimistic 用於批處理修改
他們的常量值定義分別是:
adLockReadOnly = 1
adLockPessimistic = 2
adLockOptimistic = 3
adLockBatchOptimistic = 4
rs.open sql,conn,1,1 讀取記錄 select
rs.open sql,conn,1,3 只更新記錄最好 update
rs.open sql,conn,2,3 插入和刪除最好 insert delete