日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

SQL之游标详解

發布時間:2024/6/5 数据库 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL之游标详解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1. 為何使用游標:

???????? 使用游標(cursor)的一個主要的原因就是把集合操作轉換成單個記錄處理方式。用SQL語言從數據庫中檢索數據后,結果放在內存的一塊區域中,且結果往往是個含有多個記錄的集合。游標機制允許用戶在SQL server內逐行地訪問這些記錄,按照用戶自己的意愿來顯示和處理這些記錄。

2. 如何使用游標:?

???? 一般地,使用游標都遵循下列的常規步驟:?

????? (1)? 聲明游標。把游標和T-SQL語句的結果集聯系起來。
????? (2)? 打開游標。
???? ?(3)? 使用游標操作數據。
????? (4)? 關閉游標。

2.1. 聲明游標??

DECLARE CURSOR語句SQL-92標準語法格式:?

DECLARE 游標名 [ INSENSITIVE ] [ SCROLL ] CURSOR??

FOR? sql-statement

?

Eg:??

Declare MycrsrVar? Cursor??

FOR Select *? FROMtbMyData

?

2.2? 打開游標??

OPEN MycrsrVar??

當游標被打開時,行指針將指向該游標集第1行之前,假如要讀取游標集中的第1行數據,必須移動行指針使其指向第1行。就本例而言,能夠使用下列操作讀取第1行數據:??

???? FETCH FIRST from E1cursor??

或 FETCH NEXT from E1cursor??

2.3????? 使用游標操作數據?

下面的示例用@@FETCH_STATUS控制在一個WHILE循環中的游標活動??

/* 使用游標讀取數據的操作如下。*/??

DECLARE E1cursor cursor????? /* 聲明游標,默認為FORWARD_ONLY游標 */??

FOR SELECT * FROM c_example??

OPEN E1cursor??????????????? /* 打開游標 */??

FETCH NEXT from E1cursor???? /* 讀取第1行數據*/??

WHILE @@FETCH_STATUS = 0???? /* 用WHILE循環控制游標活動 */??

BEGIN??

????????? FETCH NEXT from E1cursor?? /* 在循環體內將讀取其余行數據 */??

END??

CLOSE E1cursor?????????????? /* 關閉游標 */??

DEALLOCATE E1cursor????????? /* 刪除游標 */

?

2.4???? 關閉游標??

使用CLOSE語句關閉游標??

CLOSE { { [ GLOBAL ] 游標名 } | 游標變量名 }??

?

使用DEALLOCATE語句刪除游標,其語法格式如下:??

DEALLOCATE { { [ GLOBAL ] 游標名 } | @游標變量名?

?

3.? FETCH操作的簡明語法如下:?

FETCH??

???????? [ NEXT | PRIOR | FIRST | LAST]??

FROM??

{ 游標名? | @游標變量名 } [ INTO @變量名 [,…] ]?

?

參數說明:??

NEXT?? 取下一行的數據,并把下一行作為當前行(遞增)。由于打開游標后,行指針是指向該游標第1行之前,所以第一次執行FETCH NEXT操作將取得游標集中的第1行數據。NEXT為默認的游標提取選項。??

INTO @變量名[,…]? 把提取操作的列數據放到局部變量中。列表中的各個變量從左到右和游標結果集中的相應列相關聯。各變量的數據類型必須和相應的結果列的數據類型匹配或是結果列數據類型所支持的隱性轉換。變量的數目必須和游標選擇列表中的列的數目一致。??

--------------------------------------------------------------------------------------------------------------------------------

?

每執行一個FETCH操作之后,通常都要查看一下全局變量@@FETCH_STATUS中的狀態值,以此判斷FETCH操作是否成功。該變量有三種狀態值:

?

·? 0? 表示成功執行FETCH語句。

?

· -1? 表示FETCH語句失敗,例如移動行指針使其超出了結果集。

?

· -2? 表示被提取的行不存在。

?

由于@@FETCH_STATU是全局變量,在一個連接上的任何游標都可能影響該變量的值。因此,在執行一條FETCH語句后,必須在對另一游標執行另一FETCH 語句之前測試該變量的值才能作出正確的判斷。

轉載于:https://www.cnblogs.com/Miton/archive/2011/06/01/2066131.html

總結

以上是生活随笔為你收集整理的SQL之游标详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲视频一区在线播放 | 中文在线视频 | aav在线 | 我不卡av| 亚洲专区欧美 | 双性人妖互交localhost | 日韩色综合 | 免费看污片的网站 | 日韩夫妻性生活 | 国产精品ⅴa有声小说 | 超碰人人擦 | 插入综合网 | 日韩福利一区 | 国产精品igao| 成人影音在线 | 超碰在线日韩 | av在线一区二区三区 | 日韩成人高清 | 成人午夜影视在线观看 | 国产成人精品亚洲精品色欲 | 中文字幕在线一区二区三区 | 国产成人自拍一区 | 午夜黄色一级片 | www色网| 日本黄色录像 | 中国国产黄色片 | 国产精品成人网 | 69国产精品视频免费观看 | 性少妇bbw张开 | 日日碰狠狠添天天爽无码av | 日日夜夜中文字幕 | 午夜美女视频 | 久草视频在 | 成人爽爽视频 | 一区二区三区免费在线视频 | 日产欧产va高清 | 国产尤物视频 | 无套日出白浆 | 亚洲精品久久夜色撩人男男小说 | 亚洲成人午夜影院 | 你懂的网址在线观看 | 亚洲人免费视频 | 性爱动漫 | 日本免费黄网站 | 91av观看| 自拍偷拍av | 四虎8848精品成人免费网站 | 午夜国产| 精品国产伦一区二区三区 | 日韩在线视频二区 | 另类视频在线观看 | 欧美激情久久久久久久 | 国产高潮失禁喷水爽到抽搐 | 国产成人自拍一区 | 天躁夜夜躁狼狠躁 | 亚洲精品国产精品乱码不99 | 精品处破女学生 | 国产亚洲精品久久久 | 椎名由奈av一区二区三区 | 国产夫妻在线视频 | 波多野吉衣一二三区乱码 | 爱爱小视频网站 | 女同性αv亚洲女同志 | 婷婷中文字幕在线 | 国产精品无码一区二区三区三 | 黄色片中国 | 性生生活大片又黄又 | 午夜影院久久久 | 久久成人综合 | 大度亲吻原声视频在线观看 | 秋霞毛片 | 免费极品av一视觉盛宴 | 女人被男人躁得好爽免费视频 | www中文字幕 | jjzz日本女人 | 美女伦理水蜜桃4 | 丰满岳乱妇在线观看中字无码 | 日韩精品999| 欧美伊人 | 最新欧美大片 | wwwxxx日本人 | 欧美日韩视频无码一区二区三 | 欧美国产在线看 | 青草视频在线免费观看 | 日本高清二区 | 成人啪啪| 好看的av网址| 丰满双乳秘书被老板狂揉捏 | 日韩黄色高清视频 | 插我舔内射18免费视频 | 亚洲最大av网 | 亚洲av无码一区二区三区网址 | 开心激情深爱 | 姐姐你真棒插曲快来救救我电影 | 精品一区二区免费看 | 精品在线视频免费观看 | 亚洲激情av在线 | 二区欧美 | 成人尹人 |