欢迎来到站长教程网!

MySQL

当前位置:主页 > 数据库 > MySQL >

MySql视图触发器存储过程详解(2)

时间:2020-05-22|栏目:MySQL|点击:

delimiter // create procedure p5( in n1 int, out n2 int ) begin 1 声明如果出现异常执行( set n2=1; rollback; ) 2 开始事务 购买方账号-100 卖放账号+100 commit 3 结束 set n2=2 end // delimiter ; 这样 既可以通过n2 检测后到错误 也可以回滚 以下是详细代码 delimiter // create procedure p6( out code TINYINT ) begin 声明如果碰到sqlexception 异常就执行下边的操作 DECLARE exit HANDLER for SQLEXCEPTION begin --error set code=1; rollback; end; START TRANSACTION; delete from tb1; insert into tb2(name)values('slkdjf') commit; ---success code=2 end // delimiter ;

    游标在存储过程中的使用:

delimiter // create procedure p7() begin declare row_id int; declare row_num int; declare done int DEFAULT FALSE; 声明游标 declare my_cursor cursor for select id,num from A; 声明如果没有数据 则将done置为True declare continue handler for not found set done=True; open my_cursor; 打开游标 xxoo;LOOP 开启循环叫xxoo fetch my_cursor into row_id,row_num; if done then 如果done为True 离开循环 leave xxoo; end if; set temp=row_id+row_num; insert into B(number)VALUES(temp); end loop xxoo; 关闭循环 close my_cursor; end // delimiter ; 以上代码 转化成python for row_id,row_num in my_cursor: 检测循环中是否还有数据,如果没有则跳出 break break insert into B(num) values(row_id+row_num)

    动态的执行sql,数据库层面放置sql注入:

delimiter \\ create procedure p6( in nid int) begin 1 预编译(预检测)某个东西 sql语句合法性 2 sql=格式化tpl+arg 3 执行sql set @nid=nid prepare prod from 'select * from student where sid>?' EXECUTE prod using @ nid; deallocate prepare prod end \\ delimiter ;

上一篇:mysql闪回工具binlog2sql安装配置教程详解

栏    目:MySQL

下一篇:linux 之centos7搭建mysql5.7.29的详细过程

本文标题:MySql视图触发器存储过程详解(2)

本文地址:http://www.blue1000.com/shujuku/MySQL/1346.html

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:1961407250 | 邮箱:1961407250#qq.com(#换成@)

Copyright © 2002-2022 BK网络学院版权所有 Power by DedeCms 粤ICP备19027147号-7