mysql預存程序和遊標以及if-else,while典型執行個體

來源:互聯網
上載者:User

標籤:ar   io   os   sp   for   on   art   bs   cti   

-- --------------------------------------------------------------------------------
-- Routine DDL
-- Note: comments before and after the routine body will not be stored by the server
-- --------------------------------------------------------------------------------
DELIMITER $$

CREATE DEFINER=`root`@`%` PROCEDURE `P_ReleaseIp`(
In reip varchar(20),
in remac varchar(20),
in ipmode varchar(20),
out out_result int)
BEGIN
#釋放的IP
DECLARE t_error INTEGER DEFAULT 0;
    declare t_pid INTEGER DEFAULT 0;
    DECLARE vlannum INTEGER;
    declare m_switch varchar(20);
    declare m_port varchar(20);

    declare cur_release CURSOR for
    select Switch,`Port` from VlanBindDefaultSwtich
    where VlanId=(select ResourceId from AllResourceIpInfo where IpValue=funGetIPValue(reip));

    declare zw_switchport CURSOR for
    SELECT switch,`port` FROM IpManage_v2.StaticIpMacBindInfo
    where ip= reip and mac=remac;

    DECLARE CONTINUE HANDLER FOR SQLSTATE ‘02000‘ SET t_pid = 1;
    DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error=1;

    select VlanNumber into vlannum from VlanInfo where funGetIPValue(reip) BETWEEN StartIpValue and EndIpValue;
    START TRANSACTION;
    if ipmode=‘禁用‘ THEN
          delete from IpDisabledInfo where IpValue=funGetIPValue(reip);
          DELETE from StaticIpMacBindInfo where Ip=reip and Mac=‘10:00:00:00:00:01‘;
        /*DELETE from Ipswitcher where Ip=reip;*/
        update AllResourceIpInfo set State=1 where IpValue=funGetIPValue(reip) and State=2;   
        open cur_release;
            FETCH cur_release into m_switch,m_port;
            while t_pid<>1 AND t_error<>1 DO
                insert into StaticIpMacBindTaskInfo(Ip,Mac,Switch,Type,Port,Vlan,VpnInst,CreateTime)
                values(reip,‘10:00:00:00:00:01‘,m_switch,‘unbind‘,m_port,vlannum,0,DATE_FORMAT(NOW(),‘%Y-%m-%d %T‘));
            FETCH cur_release into m_switch,m_port;
            end while;
            close cur_release;
    elseif ipmode=‘保護‘ then
        delete from IpProtectedInfo where Ip=reip;
        DELETE from IpProtectedMacList where Ip=reip and Mac=remac;
        update AllResourceIpInfo set State=1 where IpValue=funGetIPValue(reip) and State=3;
    elseif ipmode=‘綁定‘ THEN       

        delete from IpBindedInfo where Ip=reip and Mac=remac;
        delete from StaticIpMacBindInfo where Ip=reip and Mac=remac;       
        update AllResourceIpInfo set State=1 where IpValue=funGetIPValue(reip) and State=4;
        open zw_switchport;
            FETCH zw_switchport into m_switch,m_port;
            while t_pid<>1 AND t_error<>1 DO
                insert into StaticIpMacBindTaskInfo(Ip,Mac,Switch,Type,Port,Vlan,CreateTime)
                values(reip,remac,m_switch,‘unbind‘,m_port,vlannum,DATE_FORMAT(NOW(),‘%Y-%m-%d %T‘));
            FETCH zw_switchport into m_switch,m_port;
            end while;
        close zw_switchport;
    end if;
    if t_error=1 THEN   
        ROLLBACK;set out_result=0;
    ELSE
        COMMIT;set out_result=1;
    end if;
END

mysql預存程序和遊標以及if-else,while典型執行個體

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.