欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql的游標(biāo)的定義使用及關(guān)閉深入分析

 更新時(shí)間:2012年12月18日 17:40:57   作者:  
于游標(biāo)的用法Mysql現(xiàn)在提供的還很特別,雖然使用起來(lái)沒(méi)有PL/SQL那么順手,不過(guò)使用上大致上還是一樣,本文將詳細(xì)介紹一下,需要了解的朋友可以參考下
Mysql從5.0開(kāi)始支持存儲(chǔ)過(guò)程和trigger,給我們喜歡用mysql的朋友們更喜歡mysql的理由了,語(yǔ)法上和PL/SQL有差別,不過(guò)搞過(guò)編程的人都知道,語(yǔ)法不是問(wèn)題,關(guān)鍵是思想,大致了解語(yǔ)法后,就從變量定義,循環(huán),判斷,游標(biāo),異常處理這個(gè)幾個(gè)方面詳細(xì)學(xué)習(xí)了。關(guān)于游標(biāo)的用法Mysql現(xiàn)在提供的還很特別,雖然使用起來(lái)沒(méi)有PL/SQL那么順手,不過(guò)使用上大致上還是一樣,

定義游標(biāo)
declare fetchSeqCursor cursor for select seqname, value from sys_sequence;

使用游標(biāo)
open fetchSeqCursor;
fetch數(shù)據(jù)
fetch cursor into _seqname, _value;

關(guān)閉游標(biāo)
close fetchSeqCursor;
不過(guò)這都是針對(duì)cursor的操作而已,和PL/SQL沒(méi)有什么區(qū)別吧,不過(guò)光是了解到這個(gè)是根本不足以寫出Mysql的fetch過(guò)程的,還要了解其他的更深入的知識(shí),我們才能真正的寫出好的游標(biāo)使用的procedure
首先f(wàn)etch離不開(kāi)循環(huán)語(yǔ)句,那么先了解一下循環(huán)吧。
我一般使用Loop和while覺(jué)得比較清楚,而且代碼簡(jiǎn)單。

這里使用Loop為例
復(fù)制代碼 代碼如下:

fetchSeqLoop:Loop
fetch cursor into _seqname, _value;
end Loop;

現(xiàn)在是死循環(huán),還沒(méi)有退出的條件,那么在這里和oracle有區(qū)別,Oracle的PL/SQL的指針有個(gè)隱性變量%notfound,Mysql是通過(guò)一個(gè)Error handler的聲明來(lái)進(jìn)行判斷的,
declare continue handler for Not found (do some action);
在Mysql里當(dāng)游標(biāo)遍歷溢出時(shí),會(huì)出現(xiàn)一個(gè)預(yù)定義的NOT FOUND的Error,我們處理這個(gè)Error并定義一個(gè)continue的handler就可以叻,關(guān)于Mysql Error handler可以查詢Mysql手冊(cè)定義一個(gè)flag,在NOT FOUND,標(biāo)示Flag,在Loop里以這個(gè)flag為結(jié)束循環(huán)的判斷就可以叻。
復(fù)制代碼 代碼如下:

declare fetchSeqOk boolean; ## define the flag for loop judgement
declare _seqname varchar(50); ## define the varient for store the data
declare _value bigint(20);
declare fetchSeqCursor cursor for select seqname, value from sys_sequence;## define the cursor
declare continue handler for NOT FOUND set fetchSeqOk = true; ## define the continue handler for not
found flag
set fetchSeqOk = false;
open fetchSeqCursor;
fetchSeqLoop:Loop
if fetchSeqOk then
leave fetchSeqLoop;
else
fetch cursor into _seqname, _value;
select _seqname, _value;
end if;
end Loop;
close fetchSeqCursor;

這就是一個(gè)完整的過(guò)程叻,那么會(huì)思考的人一般在這里都會(huì)思考,如果是這樣的話,怎樣做嵌套的游標(biāo)循環(huán)叻,這里可以根據(jù)statement block的scope實(shí)現(xiàn)叻,Mysql里通過(guò)begin end來(lái)劃分一個(gè)statement block,在block里定義的變量范圍也在這個(gè)block里,所以關(guān)于嵌套的游標(biāo)循環(huán)我們可以多加一個(gè)begin end來(lái)區(qū)分他們所對(duì)應(yīng)的error handler(注意在Mysql里同一個(gè)error的handler只能定義一次,多定義的話,在compile的過(guò)程中會(huì)提示里duplicate handler defination,所以NOT FOUND的handler就只能定義一次),在一個(gè)begin end里定義這個(gè)里面游標(biāo)的NOT FOUND handler,
復(fù)制代碼 代碼如下:

declare fetchSeqOk boolean; ## define the flag for loop judgement
declare _seqname varchar(50); ## define the varient for store the data
declare _value bigint(20);
declare fetchSeqCursor cursor for select seqname, value from sys_sequence;## define the cursor
declare continue handler for NOT FOUND set fetchSeqOk = true; ## define the continue handler for not
found flag
set fetchSeqOk = false;
open fetchSeqCursor;
fetchSeqLoop:Loop
if fetchSeqOk then
leave fetchSeqLoop;
else
fetch cursor into _seqname, _value;
begin
declare fetchSeqOk boolean default 'inner';
declare cursor2 cursor for select .... from ...;## define the cursor
declare continue handler for NOT FOUND set fetchSeqOk = true; ## define the continue handler for n
ot
set fetchSeqOk = false;
open cursor2;
fetchloop2 loop
if fetchSeqOk then
else
end if;
end loop;
close cursor2;
end;
end if;
end Loop;
close fetchSeqCursor;

這樣就可以輕松實(shí)現(xiàn)更多層次的循環(huán)了,不過(guò)相對(duì)oracle的PL/SQL來(lái)說(shuō),Mysql現(xiàn)在還不支持動(dòng)態(tài)游標(biāo)的定義,所以很強(qiáng)大的動(dòng)態(tài)拼出SQL的在游標(biāo)里還不能做到,不過(guò)這完全不影響我對(duì)Mysql的喜愛(ài)程度,她就想那羞澀的荷花一樣,雖然沒(méi)有燦爛的色彩,但那簡(jiǎn)約的色調(diào),清新而不染一絲鉛塵的高雅,一樣吸引著無(wú)數(shù)的mysql迷么,正如接天蓮葉無(wú)窮碧,映日荷花別樣紅。

:Mysql也有類似Oracle里的execute immediate的動(dòng)態(tài)SQL的功能,通過(guò)這個(gè)功能可有多少?gòu)浹a(bǔ)一些動(dòng)態(tài)游標(biāo)的缺憾叻
set @sqlStr='select * from table where condition1 = ?';
prepare s1 for @sqlStr;
execute s1 using @condition1; 如果有多個(gè)參數(shù)用逗號(hào)分隔
deallocate prepare s1; 手工釋放,或者是connection關(guān)閉時(shí),server自動(dòng)回收。

相關(guān)文章

  • MySQL性能優(yōu)化

    MySQL性能優(yōu)化

    MySQL是目前使用最多的開(kāi)源數(shù)據(jù)庫(kù),但是MySQL數(shù)據(jù)庫(kù)的默認(rèn)設(shè)置性能非常的差,僅僅是一個(gè)玩具數(shù)據(jù)庫(kù)。因此在產(chǎn)品中使用MySQL數(shù)據(jù)庫(kù)必須進(jìn)行必要的優(yōu)化
    2013-02-02
  • mysql導(dǎo)入csv的4種報(bào)錯(cuò)的解決方法

    mysql導(dǎo)入csv的4種報(bào)錯(cuò)的解決方法

    這篇文章主要介紹了mysql導(dǎo)入csv的4種報(bào)錯(cuò)的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Ubuntu下MySQL中文亂碼的問(wèn)題解決

    Ubuntu下MySQL中文亂碼的問(wèn)題解決

    對(duì)于MySQL中文亂碼問(wèn)題(我的是Ubuntu系統(tǒng)),在網(wǎng)上看了很多解決方案,期間也走了不少?gòu)澛?,所以想著根?jù)自己的解決之路寫一篇文章分享給有需要的朋友們,所以這篇文章主要介紹了如何解決Ubuntu下MySQL中文亂碼問(wèn)題的相關(guān)資料,需要的朋友可以參考借鑒。
    2017-02-02
  • mysql跨服務(wù)查詢之FEDERATED存儲(chǔ)引擎的實(shí)現(xiàn)

    mysql跨服務(wù)查詢之FEDERATED存儲(chǔ)引擎的實(shí)現(xiàn)

    本文主要介紹了mysql跨服務(wù)查詢之FEDERATED存儲(chǔ)引擎的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • 你知道m(xù)ysql中空值和null值的區(qū)別嗎

    你知道m(xù)ysql中空值和null值的區(qū)別嗎

    這篇文章主要給大家介紹了關(guān)于mysql中空值和null值區(qū)別的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • MySQL的數(shù)據(jù)類型和建庫(kù)策略分析詳解

    MySQL的數(shù)據(jù)類型和建庫(kù)策略分析詳解

    無(wú)論是在小得可憐的免費(fèi)數(shù)據(jù)庫(kù)空間或是大型電子商務(wù)網(wǎng)站,合理的設(shè)計(jì)表結(jié)構(gòu)、充分利用空間是十分必要的。這就要求我們對(duì)數(shù)據(jù)庫(kù)系統(tǒng)的常用數(shù)據(jù)類型有充分的認(rèn)識(shí)。下面我就將我的一點(diǎn)心得寫出來(lái)跟大家分享。
    2008-04-04
  • MySQL如何保證備份數(shù)據(jù)的一致性詳解

    MySQL如何保證備份數(shù)據(jù)的一致性詳解

    在高并發(fā)的場(chǎng)景下,大量的請(qǐng)求直接訪問(wèn)Mysql很容易造成性能問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于MySQL如何保證備份數(shù)據(jù)一致性的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • mysql怎么設(shè)置最大連接數(shù)詳解

    mysql怎么設(shè)置最大連接數(shù)詳解

    這篇文章主要給大家介紹了關(guān)于mysql怎么設(shè)置最大連接數(shù)的相關(guān)資料,設(shè)置mysql最大連接數(shù)的方法,首先打開(kāi)mysql的控制臺(tái),然后輸入語(yǔ)句set GLOBAL max_connections=1000;即可直接設(shè)置最大連接數(shù),需要的朋友可以參考下
    2022-02-02
  • 使用xtrabackup實(shí)現(xiàn)mysql備份

    使用xtrabackup實(shí)現(xiàn)mysql備份

    Xtrabackup 是percona公司的開(kāi)源項(xiàng)目,用以實(shí)現(xiàn)類似innodb官方的熱備份工具InnoDB Hot Backup的功能,能夠非??焖俚貍浞菖c恢復(fù)MySQL數(shù)據(jù)庫(kù)。今天我們就來(lái)詳細(xì)討論下Xtrabackup的使用方法
    2016-11-11
  • MySQL中的LOCATE和POSITION函數(shù)使用方法

    MySQL中的LOCATE和POSITION函數(shù)使用方法

    不常用:MySQL中的LOCATE和POSITION函數(shù)
    2010-02-02

最新評(píng)論