1

我对mysql中的存储过程有一些问题。这是我的存储过程代码:

DELIMITER $$

CREATE PROCEDURE `projects_grid`(in pagination varchar(100))
BEGIN
DECLARE a,b INT;
declare percent float;
DECLARE cur_1 CURSOR FOR SELECT id FROM tbl_projects;
    DECLARE CONTINUE HANDLER FOR NOT FOUND
SET b = 1;
drop temporary  table IF EXISTS tbl_temp ;
create Temporary table tbl_temp(id int,name varchar(100) charset utf8,project_name varchar(100) charset utf8,project_type varchar(100) charset utf8,start_date int,end_date int,percent varchar(5));
OPEN cur_1;
REPEAT
FETCH cur_1 INTO a;
set @name='';
set @project_type='';
set @project_name='';
set @b_date='';
set @e_date='';
set @percent='';
set @e_id='';
set @p_id='';
set @completed_rows_count=0;
set @rows_count=0;
select project, (select name from tbl_client where id=tbl_projects.employer_id) as name,(select name from tbl_project_type where id=tbl_projects.project_type_id) as project_name,contract_begin_date,contract_terminate_date into @project_name,@name,@project_type,@b_date,@e_date from tbl_projects where id=a;
SELECT count(PS.status) into @completed_rows_count FROM  tbl_projects_status AS PS JOIN tbl_projects_results AS S ON PS.projects_results_id = S.id where project_id=a and PS.status='1';
SELECT count(PS.status) into @rows_count FROM tbl_projects_status AS PS JOIN tbl_projects_results AS S ON PS.projects_results_id = S.id where project_id=a;
set percent=(@completed_rows_count/@rows_count)*100;
insert into tbl_temp values(a,@project_name,@name,@project_type,@b_date,@e_date,concat(percent,'%'));
UNTIL b = 1
END REPEAT;
CLOSE cur_1;
set @pagination=pagination;
set @query=concat('SELECT distinct(id),name,project_name,project_type,start_date,end_date,percent FROM tbl_temp ',@pagination);
PREPARE stmp FROM @query;
EXECUTE stmp;
DEALLOCATE PREPARE stmp;
END

这是我的 php 代码:

<?php
require_once 'bootstrap.php';
$query="call projects_grid('')";
$result=mysql_fetch_array(mysql_query($query));
foreach($result as $record)
{
    echo $record;
}
$query="select count(*) from tbl_projects";
$result=mysql_query($query); // Boolean false given :(
$result=mysql_fetch_row($result);
echo $result[0];
?>

当我在程序之后执行查询时,在调试模式下,系统显示我给定的布尔值是 false!。如何在调用存储过程后执行查询?

4

2 回答 2

2

最后我找到了答案:使用 mysqli 而不是 mysql。

$mysqli = new mysqli('your_hostname','your_username' ,'your_password','your_db_name');
$result=$mysqli->query($query);
$result->data_seek(0);

执行查询后,您必须使用以下命令:

mysqli_free_result();
mysqli_next_result($mysqli);

祝你好运!

于 2013-02-28T07:18:43.887 回答
0

mysql_query()我们可以在其手册页中找到该功能的使用示例:

$result = mysql_query('SELECT * WHERE 1=1');
if (!$result) {
    die('Invalid query: ' . mysql_error());
}

总结一下:

  1. mysql_query()false查询失败时返回
  2. mysql_error()返回错误信息

PS 您还可以看到“此扩展自 PHP 5.5.0 起已弃用,将来将被删除”警告,但我想您已经知道了。

编辑:命令不同步;您现在无法运行此命令”错误消息通常可以通过使用mysql_free_result()释放先前的结果集来修复。并不是说您的存储过程一定有问题——遗留的 mysql 扩展在设计时并没有真正考虑到存储例程。

于 2013-02-06T09:07:52.247 回答