如何查看mysqlmysql 存储过程执行慢结束

在 SegmentFault,解决技术问题
每个月,我们帮助 1000 万的开发者解决各种各样的技术问题。并助力他们在技术能力、职业生涯、影响力上获得提升。
一线的工程师、著名开源项目的作者们,都在这里:
获取验证码
已有账号?
问题对人有帮助,内容完整,我也想知道答案
问题没有实际价值,缺少关键内容,没有改进余地
sqlalchemy 如何执行mysql的存储过程并获取返回结果?
同步到新浪微博
分享到微博?
关闭理由:
删除理由:
忽略理由:
推广(招聘、广告、SEO 等)方面的内容
与已有问题重复(请编辑该提问指向已有相同问题)
答非所问,不符合答题要求
宜作评论而非答案
带有人身攻击、辱骂、仇恨等违反条款的内容
无法获得确切结果的问题
非开发直接相关的问题
非技术提问的讨论型问题
其他原因(请补充说明)
我要该,理由是:Mysql命令和存储过程及其调用_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
Mysql命令和存储过程及其调用
&&mysql简单命令和存储过程及其调用
阅读已结束,下载文档到电脑
想免费下载本文?
定制HR最喜欢的简历
下载文档到电脑,方便使用
还剩22页未读,继续阅读
定制HR最喜欢的简历
你可能喜欢实例解析MySQL中的存储过程及存储过程的调用方法
作者:hudeyong926
字体:[ ] 类型:转载 时间:
存储例程是存储在数据库服务器中的一组sql语句,通过在查询中调用一个指定的名称来执行这些sql语句命令,下面就以实例解析MySQL中的存储过程及存储过程的调用方法:
mysql在5.1之后增加了存储过程的功能, 存储过程运行在mysql内部,语句都已经编译好了,速度比sql更快. 存储过程与mysql相当于shell和linux系统。如果你是程序员的话,那我告诉你存储过程实际上是一个方法,你只要调用这个方法,并且输入它设置好的参数就可以获取或者执行你想要的操作了. 看了如下存储过程实例,你会发现mysql存储过程和shell很像.
下面存储过程内容为:调用存储过程,并且传入用户名,密码参数。存储过程会将这她们存储到process_test表里面.看实例
一,创建数据库
mysql&create database db_
二,创建表
mysql&CREATE TABLE `proc_test` (
`id` tinyint(4) NOT NULL AUTO_INCREMENT, #ID,自动增长
`username` varchar(20) NOT NULL, #用户名
`password` varchar(20) NOT NULL, #密码
PRIMARY KEY (`id`) #主键
) ENGINE=MyISAM AUTO_INCREMENT=50 DEFAULT CHARSET=utf8; #设置表引擎和字符集
三、创建存储过程
create procedure mytest(in name varchar(20),in pwd varchar(20))#定义传入的参数
insert into proc_test(username,password) values(name,pwd);
#把传进来的参数name和pwd插入表中,别忘记分号
#注意这个分号别忘记了
create procedure mytest(in name varchar(20),in pwd varchar(20))#定义传入的参数
insert into proc_test(username,password) values(name,pwd);
#把传进来的参数name和pwd插入表中,别忘记分号
#注意这个分号别忘记了
四、测试调用存储过程
用法:call 存储过程名称(传入的参数)
call proc_test("绝心是凉白开","www.jb51.net")
username为”绝心是凉白开“传入数据库中,密码”www.jb51.net“
五、查看数据库中有无加入的数据
select * from proc_test where username=‘绝心是凉白开';#如果有内容说明成功了
六、删除存储过程
drop procdure 存储过程名;
七、通用分页存储过程代码及调用
DROP PROCEDURE IF EXISTS pr_
CREATE PROCEDURE pr_pager(
p_table_name
VARCHAR(1024),
VARCHAR(1024),
/*查询字段*/
p_page_size
/*每页记录数*/
p_page_now
/*当前页*/
p_order_string
VARCHAR(128),
/*排序条件(包含ORDER关键字,可为空)*/
p_where_string
VARCHAR(1024),
/*WHERE条件(包含WHERE关键字,可为空)*/
p_out_rows
/*输出记录总数*/
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT '分页存储过程'
/*定义变量*/
DECLARE m_begin_row INT DEFAULT 0;
DECLARE m_limit_string CHAR(64);
/*构造语句*/
SET m_begin_row = (p_page_now - 1) * p_page_
SET m_limit_string = CONCAT(' LIMIT ', m_begin_row, ', ', p_page_size);
SET @COUNT_STRING = CONCAT('SELECT COUNT(*) INTO @ROWS_TOTAL FROM ', p_table_name, ' ', p_where_string);
SET @MAIN_STRING = CONCAT('SELECT ', p_fields, ' FROM ', p_table_name, ' ', p_where_string, ' ', p_order_string, m_limit_string);
/*预处理*/
PREPARE count_stmt FROM @COUNT_STRING;
EXECUTE count_
DEALLOCATE PREPARE count_
SET p_out_rows = @ROWS_TOTAL;
PREPARE main_stmt FROM @MAIN_STRING;
EXECUTE main_
DEALLOCATE PREPARE main_
1.取记录调用:
call pr_pager('表名', '*', 25, 1, '', '', @count_rows);
call pr_pager('user', '*', 15, 2, '', 'where id&3', @count_rows);
call pr_pager('user', '*', 15, 1, 'group by password order by id desc', '', @count_rows);
2.调用1后再取条数调用:
select @count_
select @MAIN_STRING //select sql
select @COUNT_STRING //seelct count sql
支持多表级联 ,分组 :
call pr_pager('job j left join enter_job ej on j.job_no=ej.job_no','j.*,ej.*','25','1','group by ej.put_away_user order by ej.put_away_user desc','where j.job_table="enter"',@p_out_rows);
function dump_single_form41report($sys_report_id) {
$this-&dbConn-&setFetchMode(DB_FETCHMODE_ASSOC);
//SET @a=1;CALL dbpi_report.simpleproc(@a);SELECT @a;
$sql = "CALL dbpi_temp.dumpSingleReportForm41($sys_report_id);";
$result = $this-&dbConn-&query($sql);
if (mysql_error()) {
die (mysql_error().'&b&:&/b& dump_single_form41report(...)['.__LINE__.'];&br&'.$sql);
function initQueuePool($sys_report_id, $username){
$this-&dbConn-&setFetchMode(DB_FETCHMODE_ASSOC);
$this-&checkPreviousThread($sys_report_id, $username);
$temptablename = "_".$username."_".$sys_report_
$sql = "SET @a=".$sys_report_id.";";
$this-&dbConn-&query($sql);
$sql = "SET @b='".DB_REPORT.".".$temptablename."';";
$this-&dbConn-&query($sql);
$sql = "SET @c='".DB_PREPRODUCT."';";
$this-&dbConn-&query($sql);
$sql = "CALL ".DB_REPORT.".fm41_simpleproc(@a,@b,@c);";
$this-&dbConn-&query($sql);
普通的查询,只返回一个结果集,而存储过程却返回至少两个结果集,其中一个就是存储过程的执行状态。我们必须要清除了这个执行状态以后,才可能再次调用另外一个存储过程 。
$rs=mysql_query("call pr_pager('change_monitor','*',10,1,'','',@p_out_rows)");
while($rows=mysql_fetch_array($rs)){
echo $rows[Schedule];
$query=mysql_query("select @p_out_rows");
$v=mysql_fetch_array($query);
can't return a result set in the given context
需要php调用存储过程,返回一个结果集,发现很困难,找了半天,终于在老外的论坛上找到解决方案,这里本地化一下。
关键就是两点:
define('CLIENT_MULTI_RESULTS', 131072);
$link = mysql_connect("127.0.0.1", "root", "",1,CLIENT_MULTI_RESULTS) or die("Could not connect: ".mysql_error());
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!&&|&&
做真实的自己
LOFTER精选
网易考拉推荐
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
阅读(5575)|
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
历史上的今天
loftPermalink:'',
id:'fks_',
blogTitle:'MySQL存储过程在动态sql内获取返回值',
blogAbstract:'不需要使用游标循环来读取,直接select * into @变量就OK了,还可以传递参数来执行。 1MySql通用分页存储过程 2 3过程参数 4p_cloumns varchar(500),p_tables varchar(100),p_where varchar(4000),p_order varchar(100),p_pageindex int,p_pagesize int,out p_recordcount int,out p_pagecount int 5 6$$:begin 7
declare v_sqlcounts varchar(4000); 8
declare v_sqlselect varchar(4000); 9
#拼接查询总记录的SQL语句10
set v_sqlcounts',
blogTag:'mysql,procedure',
blogUrl:'blog/static/',
isPublished:1,
istop:false,
modifyTime:6,
publishTime:1,
permalink:'blog/static/',
commentCount:0,
mainCommentCount:0,
recommendCount:0,
bsrk:-100,
publisherId:0,
recomBlogHome:false,
currentRecomBlog:false,
attachmentsFileIds:[],
groupInfo:{},
friendstatus:'none',
followstatus:'unFollow',
pubSucc:'',
visitorProvince:'',
visitorCity:'',
visitorNewUser:false,
postAddInfo:{},
mset:'000',
remindgoodnightblog:false,
isBlackVisitor:false,
isShowYodaoAd:false,
hostIntro:'做真实的自己',
hmcon:'0',
selfRecomBlogCount:'0',
lofter_single:''
{list a as x}
{if x.moveFrom=='wap'}
{elseif x.moveFrom=='iphone'}
{elseif x.moveFrom=='android'}
{elseif x.moveFrom=='mobile'}
${a.selfIntro|escape}{if great260}${suplement}{/if}
{list a as x}
推荐过这篇日志的人:
{list a as x}
{if !!b&&b.length>0}
他们还推荐了:
{list b as y}
转载记录:
{list d as x}
{list a as x}
{list a as x}
{list a as x}
{list a as x}
{if x_index>4}{break}{/if}
${fn2(x.publishTime,'yyyy-MM-dd HH:mm:ss')}
{list a as x}
{if !!(blogDetail.preBlogPermalink)}
{if !!(blogDetail.nextBlogPermalink)}
{list a as x}
{if defined('newslist')&&newslist.length>0}
{list newslist as x}
{if x_index>7}{break}{/if}
{list a as x}
{var first_option =}
{list x.voteDetailList as voteToOption}
{if voteToOption==1}
{if first_option==false},{/if}&&“${b[voteToOption_index]}”&&
{if (x.role!="-1") },“我是${c[x.role]}”&&{/if}
&&&&&&&&${fn1(x.voteTime)}
{if x.userName==''}{/if}
网易公司版权所有&&
{list x.l as y}
{if defined('wl')}
{list wl as x}{/list}mysql如何跳出存储过程的执行 - CSDN博客
mysql如何跳出存储过程的执行
&很多小伙伴都知道使用leave label来跳出循环,但是在实际的需求可能需要跳出整个存储过程而mysql又不支持quit,exit或return的方式退出。
这里我们依然使用leave的方式来模拟exit的作用(见2)。
1,一般用法,跳出循环
&Create Procedure: CREATE DEFINER=`root`@`localhost` PROCEDURE `test`(p1 INT)
& label1: LOOP
& & SET p1 = p1 + 1;
& & IF p1 & 10 THEN&
& & &select 'repeate';
& & &ITERATE label1;&
& & END IF;
& & select 'skip';
& & LEAVE label1;&
& END LOOP label1;
& SET @x = p1;
& select @x; &
MariaDB [test]& call test(8);
+---------+
| repeate |
+---------+
| repeate |
+---------+
1 row in set (0.00 sec)
+------+
+------+
+------+
1 row in set (0.00 sec)
+------+
+------+
+------+ &
2,直接跳出整个存储过程体
CREATE DEFINER=`root`@`localhost` PROCEDURE b (p int)&
label:begin&
if i&1 then &&
调用如下:
传入参数小于1 直接跳出存储过程
&call b(-1);
Query OK, 0 rows affected (0.00 sec)
传入参数大于1 直接输出传入的值
call b(2);&
+------+
+------+
+------+
实际结果和测试情况一致。
就简单的记录到此,希望对你有帮助。
本文已收录于以下专栏:
相关文章推荐
mysql 的存储过程是不能使用 return 语句的,只有存储函数才有此功能。那么,有没有替代 return 的关键字呢?
    没有!
    像 exit, quit 之类的关键字全没有!...
SQL Code复制内容到剪贴板
  
mysql& delimiter $$   
mysql&   
mysql& CREATE PR...
一、MYSQL储存过程简介:
储存过程是一个可编程的函数,它在数据库中创建并保存。它可以有SQL语句和一些特殊的控制结构组成。当希望在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过...
存储过程与函数的区别  本质上没区别,执行的本质都一样。
  只是函数有如:只能返回一个变量的限制。而存储过程可以返回多个。  
  函数是可以嵌入在sql中使用的,可以在select中调用,而存...
CREATE PROCEDURE `proname`(uid int,rid int,out errorno int,...)
 ....
当MySQL执行存储过程遇到错误时,适当处理它,如继续执行或退出当前代码段,并返回有意义的错误提示是很重要的。一方面提高程序的容错能力,另一方便当程序出错时,开发人员也能准确定位错误的地方。
1、查询是否锁表show OPEN TABLES where In_use & 0;2、查询进程
show processlist
查询到相对应的进程,然后 kill
通常,我们在进行数据操作时,通过定义存储过程会带来很大的便捷,但是如果存储过程中间出现错误,并且该过程中执行sql语句众多,排查错误就会变得很困难,会花费很大的时间去查找确认错误的缘由,可以将原定义的...
在PHP同一事物里调用MYSQL的存储过程后再次执行另外的一个或多个命令(或者在同一事物里执行多个存储过程),如果使用mysqli的query方法获得结果,将获得一个错误:Commands out o...
第一步:修改/f文件,找到[mysqld] 里面加入
#执行的sql
log=/tmp/logs/mysqld.log
#记录sql执行超过下面设置时间的sql
log-slo...
他的最新文章
讲师:何宇健
讲师:董岩
您举报文章:
举报原因:
原文地址:
原因补充:
(最多只允许输入30个字)

我要回帖

更多关于 mysql 结束存储过程 的文章

 

随机推荐