午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    sql關(guān)于游標(biāo)和游標(biāo)、存儲過程結(jié)合具體使用
    來源:易賢網(wǎng) 閱讀:2649 次 日期: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;

    --這是定義一個(gè)游標(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)提取選項(xiàng)。

    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;

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

    --如果我們要返回一個(gè)游標(biāo)的返回值,那么我們的游標(biāo)的這個(gè)參數(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;--這句代碼是個(gè)關(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)一個(gè)小例子 問題描述:有以下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)的一個(gè)主要的原因就是把集合操作轉(zhuǎn)換成單

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

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

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

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

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

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

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

    1.3 游標(biāo)的使用

    講了這個(gè)多游標(biāo)的優(yōu)點(diǎn),現(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)提取選項(xiàng)。

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

    列表中的各個(gè)變量從左到右與游標(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,...)

    說明:幾個(gè)高級查詢運(yùn)算詞

    A: UNION 運(yùn)算符

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

    B: EXCEPT 運(yùn)算符

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

    C: INTERSECT 運(yùn)算符

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

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

    */

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

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

    2025國考·省考課程試聽報(bào)名

    • 報(bào)班類型
    • 姓名
    • 手機(jī)號
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機(jī)站點(diǎn) | 投訴建議
    工業(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:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專用圖標(biāo)