sql關(guān)于游標(biāo)和游標(biāo)、存儲過程結(jié)合具體使用
來源:易賢網(wǎng) 閱讀:2579 次 日期:2014-09-19 11:15:12
溫馨提示:易賢網(wǎng)小編為您整理了“sql關(guān)于游標(biāo)和游標(biāo)、存儲過程結(jié)合具體使用”,方便廣大網(wǎng)友查閱!

--關(guān)于游標(biāo)的用法

--定義 Transact-SQL 服務(wù)器游標(biāo)的特性,例如游標(biāo)的滾動行為和用于生成游標(biāo)對其進(jìn)行操作的結(jié)果集的查詢。

--DECLARE CURSOR 接受基于 SQL-92 標(biāo)準(zhǔn)的語法和使用一組 Transact-SQL 擴(kuò)展的語法。

/*

@@FETCH_STATUS

返回被 FETCH 語句執(zhí)行的最后游標(biāo)的狀態(tài),而不是任何當(dāng)前被連接打開的游標(biāo)的狀態(tài)。

返回值 描述

0 FETCH 語句成功。

-1 FETCH 語句失敗或此行不在結(jié)果集中。

-2 被提取的行不存在。

*/

select * from dep;

--這是定義一個游標(biāo)

declare @id int, @name varchar(20);

declare dep_cursor cursor for

select depid, depname from dep;

--這是打開游標(biāo)

open dep_cursor;

fetch next from dep_cursor into @id, @name;

while(@@fetch_status = 0)

begin

--fetch next返回緊跟當(dāng)前行之后的結(jié)果行,并且當(dāng)前行遞增為結(jié)果行。如果 FETCH NEXT 為對游標(biāo)的第一次提取操作,

--則返回結(jié)果集中的第一行。NEXT 為默認(rèn)的游標(biāo)提取選項。

fetch next from dep_cursor into @id, @name;

print @id;

print @name;

end;

--這是關(guān)閉游標(biāo)

close dep_cursor;

--這是刪除游標(biāo)

deallocate dep_cursor;

--這是一個將游標(biāo)應(yīng)用到存儲過程的應(yīng)用

--如果我們要返回一個游標(biāo)的返回值,那么我們的游標(biāo)的這個參數(shù)必須定義為 cursor varying output

create procedure t1_cursor(@dep_cursor cursor varying output)

as

declare @id int, @name varchar(20);

set @dep_cursor = cursor for select depid,depname from dep;--這句代碼是個關(guān)鍵

open @dep_cursor;--這是打開游標(biāo)

drop procedure t1_cursor;

go

declare @t2_cursor cursor, @id int, @name varchar(20);

exec t1_cursor @t2_cursor output;

fetch next from @t2_cursor into @id, @name;

while(@@fetch_status = 0)

begin

print @id;

print @name;

fetch next from @t2_cursor into @id, @name;

end;

close @t2_cursor;

go

/*sqlser游標(biāo)一個小例子 問題描述:有以下2張表,

現(xiàn)在希望得到這樣的數(shù)據(jù)表A里的O_Saloary加上表B的A_Salary是當(dāng)前的總工資,并更新到表A。

你可以用視圖來,表連接下就可以。

現(xiàn)在我們考慮下讓SQL自己來處理,游標(biāo)就是很好的方法。

原理:游標(biāo)就是把數(shù)據(jù)按照指定要求提取出相應(yīng)的數(shù)據(jù)集,然后逐條進(jìn)行數(shù)據(jù)處理。

1.1游標(biāo)的概念

游標(biāo)(Cursor)它使用戶可逐行訪問由SQL Server返回的結(jié)果集。使用游標(biāo)(cursor)的一個主要的原因就是把集合操作轉(zhuǎn)換成單

個記錄處理方式。用SQL語言從數(shù)據(jù)庫中檢索數(shù)據(jù)后,結(jié)果放在內(nèi)存的一塊區(qū)域中,且結(jié)果往往是一個含有多個記錄的集合。

游標(biāo)機(jī)制允許用戶在SQL server內(nèi)逐行地訪問這些記錄,按照用戶自己的意愿來顯示和處理這些記錄。

1.2 游標(biāo)的優(yōu)點

從游標(biāo)定義可以得到游標(biāo)的如下優(yōu)點,這些優(yōu)點使游標(biāo)在實際應(yīng)用中發(fā)揮了重要作用:

1)允許程序?qū)τ刹樵冋Z句select返回的行集合中的每一行執(zhí)行相同或不同的操作,而不是對整個行集合執(zhí)行同一個操作。

2)提供對基于游標(biāo)位置的表中的行進(jìn)行刪除和更新的能力。

3)游標(biāo)實際上作為面向集合的數(shù)據(jù)庫管理系統(tǒng)(RDBMS)和面向行的程序設(shè)計之間的橋梁,使這兩種處理方式通過游標(biāo)溝通起來。

1.3 游標(biāo)的使用

講了這個多游標(biāo)的優(yōu)點,現(xiàn)在我們就親自來揭開游標(biāo)的神秘的面紗。

使用游標(biāo)的順序: 聲名游標(biāo)、打開游標(biāo)、讀取數(shù)據(jù)、關(guān)閉游標(biāo)、刪除游標(biāo)。

聲明游標(biāo)

最簡單游標(biāo)聲明:DECLARE <游標(biāo)名>CURSOR FOR<SELECT語句>;

其中select語句可以是簡單查詢,也可以是復(fù)雜的接連查詢和嵌套查詢

打開游標(biāo)

非常簡單,我們就打開剛才我們聲明的游標(biāo)mycursor

OPEN mycursor

讀取數(shù)據(jù)

FETCH [ NEXT | PRIOR | FIRST | LAST] FROM { 游標(biāo)名 | @游標(biāo)變量名 } [ INTO @變量名 [,…] ]

參數(shù)說明:

NEXT 取下一行的數(shù)據(jù),并把下一行作為當(dāng)前行(遞增)。由于打開游標(biāo)后,行指針是指向該游標(biāo)第1行之前,所以第一次執(zhí)行FETCH NEXT操作將取得游標(biāo)集中的第1行數(shù)據(jù)。NEXT為默認(rèn)的游標(biāo)提取選項。

INTO @變量名[,…] 把提取操作的列數(shù)據(jù)放到局部變量中。

列表中的各個變量從左到右與游標(biāo)結(jié)果集中的相應(yīng)列相關(guān)聯(lián)。

各變量的數(shù)據(jù)類型必須與相應(yīng)的結(jié)果列的數(shù)據(jù)類型匹配或是結(jié)果列數(shù)據(jù)類型所支持的隱性轉(zhuǎn)換。變量的數(shù)目必須與游標(biāo)選擇列表中的列的數(shù)目一致。

關(guān)閉游標(biāo)

CLOSE mycursor

刪除游標(biāo)

DEALLOCATE mycursor

給出具體的例子:

declare @id nvarchar(20) --定義變量來保存ID號

declare @A float --定義變量來保存值

declare mycursor cursor for select * from tb_c --為所獲得的數(shù)據(jù)集指定游標(biāo)

open mycursor --打開游標(biāo)

fetch next from mycursor into @id,@A --開始抓第一條數(shù)據(jù)

while(@@fetch_status=0) --如果數(shù)據(jù)集里一直有數(shù)據(jù)

begin

select tb_b.name,(tb_b.gz + @A) from tb_b where tb_b.id = @id --開始做想做的事(什么更新呀,刪除呀)

fetch next from mycursor into @id,@A --跳到下一條數(shù)據(jù)

end

close mycursor --關(guān)閉游標(biāo)

deallocate mycursor --刪除游標(biāo)

sql2005 判斷是否為 數(shù)字

sql 判斷是否為數(shù)字

sql語句中的isnumeric函數(shù)是用來判斷是否為數(shù)字

舉例:

select isnumeric(0)

返回值為1

select isnumeric('易心博客')

返回值為0

sql2005 update

update mis.a22 set mis.a22.名稱=dm_pdtq.dm from dm_pdtq where dm_pdtq.tqmc=mis.a22.名稱

說明,更新a22中的名稱字段為dm_pdtq.dm

========================================

說明sqlserver2005分頁處理

SELECT * FROM (select ROW_NUMBER() Over(order by bh) as rowNum, *

from Table1) as table1

where rowNum> 0 and rowNum<=50 (查詢第1頁到50頁)

說明:復(fù)制表(只復(fù)制結(jié)構(gòu),源表名:a 新表名:b)

A:select * into b from a where 1<>1

B:select top 0 * into b from a

說明:刪除重復(fù)記錄

Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...)

說明:幾個高級查詢運算詞

A: UNION 運算符

UNION 運算符通過組合其他兩個結(jié)果表(例如 TABLE1 和 TABLE2)并消去表中任何重復(fù)行而派生出一個結(jié)果表。當(dāng) ALL 隨 UNION 一起使用時(即 UNION ALL),不消除重復(fù)行。兩種情況下,派生表的每一行不是來自 TABLE1 就是來自 TABLE2。

B: EXCEPT 運算符

EXCEPT 運算符通過包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重復(fù)行而派生出一個結(jié)果表。當(dāng) ALL 隨 EXCEPT 一起使用時 (EXCEPT ALL),不消除重復(fù)行。

C: INTERSECT 運算符

INTERSECT 運算符通過只包括 TABLE1 和 TABLE2 中都有的行并消除所有重復(fù)行而派生出一個結(jié)果表。當(dāng) ALL 隨 INTERSECT 一起使用時 (INTERSECT ALL),不消除重復(fù)行。

注:使用運算詞的幾個查詢結(jié)果行必須是一致的

*/

更多信息請查看IT技術(shù)專欄

更多信息請查看數(shù)據(jù)庫
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機(jī)號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機(jī)站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報警專用圖標(biāo)