日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
游標為何物,請你看這里

昨天小編分享兩篇關(guān)于游標的文章:游標腳本性能問題詳解之案例實踐篇,游標腳本性能問題詳解之游標分類特點篇 ,并在文章中簡單對游標做了說明。今天小編找到了一篇具體介紹游標的博文,在這里與大家一起學(xué)習(xí)。

成都網(wǎng)站建設(shè)、做網(wǎng)站,成都做網(wǎng)站公司-成都創(chuàng)新互聯(lián)已向上1000家企業(yè)提供了,網(wǎng)站設(shè)計,網(wǎng)站制作,網(wǎng)絡(luò)營銷等服務(wù)!設(shè)計與技術(shù)結(jié)合,多年網(wǎng)站推廣經(jīng)驗,合理的價格為您打造企業(yè)品質(zhì)網(wǎng)站。

游標(cursor)

游標是系統(tǒng)為用戶開設(shè)的一個數(shù)據(jù)緩沖區(qū),存放SQL語句的執(zhí)行結(jié)果。每個游標區(qū)都有一個名字。用戶可以用SQL語句逐一從游標中獲取記錄,并賦給主變量,交由主語言進一步處理。主語言是面向記錄的,一組主變量一次只能存放一條記錄。僅使用主變量并不能完全滿足SQL語句向應(yīng)用程序輸出數(shù)據(jù)的要求。嵌入式SQL引入了游標的概念,用來協(xié)調(diào)這兩種不同的處理方式。

在數(shù)據(jù)庫開發(fā)過程中,當你檢索的數(shù)據(jù)只是一條記錄時,你所編寫的事務(wù)語句代碼往往使用SELECT INSERT 語句。但是我們常常會遇到這樣情況,即從某一結(jié)果集中逐一地讀取一條記錄。那么如何解決這種問題呢?游標為我們提供了一種極為優(yōu)秀的解決方案。

1.游標和游標的優(yōu)點

在數(shù)據(jù)庫中,游標是一個十分重要的概念。游標提供了一種對從表中檢索出的數(shù)據(jù)進行操作的靈活手段,就本質(zhì)而言,游標實際上是一種能從包括多條數(shù)據(jù)記錄的結(jié)果集中每次提取一條記錄的機制。游標總是與一條SQL 選擇語句相關(guān)聯(lián)因為游標由結(jié)果集(可以是零條、一條或由相關(guān)的選擇語句檢索出的多條記錄)和結(jié)果集中指向特定記錄的游標位置組成。當決定對結(jié)果集進行處理時,必須聲明一個指向該結(jié)果集的游標。如果曾經(jīng)用 C 語言寫過對文件進行處理的程序,那么游標就像您打開文件所得到的文件句柄一樣,只要文件打開成功,該文件句柄就可代表該文件。對于游標而言,其道理是相同的。可見游標能夠?qū)崿F(xiàn)按與傳統(tǒng)程序讀取平面文件類似的方式處理來自基礎(chǔ)表的結(jié)果集,從而把表中數(shù)據(jù)以平面文件的形式呈現(xiàn)給程序。

我們知道關(guān)系數(shù)據(jù)庫管理系統(tǒng)實質(zhì)是面向集合的,在MS SQL SERVER 中并沒有一種描述表中單一記錄的表達形式,除非使用where 子句來限制只有一條記錄被選中。因此我們必須借助于游標來進行面向單條記錄的數(shù)據(jù)處理。由此可見,游標允許應(yīng)用程序?qū)Σ樵冋Z句select 返回的行結(jié)果集中每一行進行相同或不同的操作,而不是一次對整個結(jié)果集進行同一種操作;它還提供對基于游標位置而對表中數(shù)據(jù)進行刪除或更新的能力;而且,正是游標把作為面向集合的數(shù)據(jù)庫管理系統(tǒng)和面向行的程序設(shè)計兩者聯(lián)系起來,使兩個數(shù)據(jù)處理方式能夠進行溝通。

2. 游標種類

MS SQL SERVER 支持三種類型的游標:Transact_SQL 游標,API 服務(wù)器游標和客戶游標。

(1) Transact_SQL 游標

Transact_SQL 游標是由DECLARE CURSOR 語法定義、主要用在Transact_SQL 腳本、存儲過程和觸發(fā)器中。Transact_SQL 游標主要用在服務(wù)器上,由從客戶端發(fā)送給服務(wù)器的Transact_SQL 語句或是批處理、存儲過程、觸發(fā)器中的Transact_SQL 進行管理。 Transact_SQL 游標不支持提取數(shù)據(jù)塊或多行數(shù)據(jù)。

(2) API 游標

API 游標支持在OLE DB, ODBC 以及DB_library 中使用游標函數(shù),主要用在服務(wù)器上。每一次客戶端應(yīng)用程序調(diào)用API 游標函數(shù),MS SQL SEVER 的OLE DB 提供者、ODBC驅(qū)動器或DB_library 的動態(tài)鏈接庫(DLL) 都會將這些客戶請求傳送給服務(wù)器以對API游標進行處理。

(3) 客戶游標

客戶游標主要是當在客戶機上緩存結(jié)果集時才使用。在客戶游標中,有一個缺省的結(jié)果集被用來在客戶機上緩存整個結(jié)果集??蛻粲螛藘H支持靜態(tài)游標而非動態(tài)游標。由于服務(wù)器游標并不支持所有的Transact-SQL 語句或批處理,所以客戶游標常常僅被用作服務(wù)器游標的輔助。因為在一般情況下,服務(wù)器游標能支持絕大多數(shù)的游標操作。由于API 游標和Transact-SQL 游標使用在服務(wù)器端,所以被稱為服務(wù)器游標,也被稱為后臺游標,而客戶端游標被稱為前臺游標。在本章中我們主要講述服務(wù)器(后臺)游標

游標詳細說明:

RS.OPEN SQL,CONN,A,B

參數(shù)A為設(shè)定游標的類型,其取值為:

0 僅向前游標,只能向前瀏覽記錄,不支持分頁、Recordset、BookMark

1 鍵集游標,其他用戶對記錄說做的修改將反映到記錄集中,但其他用戶增加或刪除記錄不會反映到記錄集中。支持分頁、Recordset、BookMark

2 動態(tài)游標功能***,但耗資源也最多。用戶對記錄說做的修改,增加或刪除記錄都將反映到記錄集中。支持全功能瀏覽。

3 靜態(tài)游標,只是數(shù)據(jù)的一個快照,用戶對記錄說做的修改,增加或刪除記錄都不會反映到記錄集中。支持向前或向后移動。

參數(shù)B為記錄集的鎖定類型,其取值為:

1 鎖定類型,默認的,只讀,不能作任何修改

2 當編輯時立即鎖定記錄,最安全的方式

3 只有在調(diào)用Update方法時才鎖定記錄集,而在此前的其他操作仍可對當前記錄進行更改、插入和刪除等

4 當編輯時記錄不會被鎖定,而更改、插入和刪除是在批處理方式下完成的

打開數(shù)據(jù)記錄集方法其實不止一種,但是我們用的最多的就是

rs.open sql,1,1的方法,可是后面的數(shù)字參數(shù)很多人不解其意,下面我們來介紹一下。

其實open方法后面有多個參數(shù)

CursorType LockType CommandType

比如 rs.open sql,1,1

也可以寫成

rs.cursorType = 1

rs.LockType = 1

rs.open sql

其中CursorType代表從一個表或者一個SQL查詢結(jié)果返回的記錄。

這個參數(shù)有四個值分別是:

adOpenForwardOnly 表示只允許在記錄集內(nèi)的記錄間往前移動。這個是缺省值。

adOpenKeyset 反映由其它用戶所做的對記錄的改變或者刪除動作,但并不反映由其它用戶做作的添加新記錄的動作。

adOpenDynamic 反映由其它用戶所做的對記錄的改變或者刪除動作,包括添加的新記錄

adOpenStatic 不反映其它用戶對記錄所做的修改,添加,刪除動作。

這四個值VBSCRIPT預(yù)定義位

adOpenForwardOnly = 0

adOpenKeyset = 1

adOpenDynamic = 2

adOpenStatic = 3

lockType 表示當打開記錄集時,數(shù)據(jù)提供者用于鎖定數(shù)據(jù)庫的類型:

adLockReadOnly 數(shù)據(jù)不能改變,這是缺省值!

adLockPessimistic 數(shù)據(jù)提供者在開始編輯數(shù)據(jù)的時候鎖定記錄

adLockOptimistic 僅當調(diào)用update方法時,數(shù)據(jù)提供者鎖定記錄

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


分享文章:游標為何物,請你看這里
分享鏈接:http://m.5511xx.com/article/coeohph.html