Jump to content

Recommended Posts

Not sure why this isn't working

 

	
$mysqli = new mysqli("IPADDRESS", "LOGIN", "PASSWORD", "DBNAME");

$result = $mysqli->query('CALL Proc_GetRegionInfo(10000001)');
$row = $result->fetch_assoc();
$regionName =  $row['regionName'];

$result = $mysqli->query('CALL Proc_GetFactionName(500007)');
$row = $result->fetch_assoc(); // Line 13
$factionName =  $row['factionName'];

 

The first query works fine, the second one fails and gives an error message of

Fatal error: Call to a member function fetch_assoc() on a non-object in ...\regiondetail.php on line 13

 

Any ideas?

 

Link to comment
https://forums.phpfreaks.com/topic/91124-stored-procedures/
Share on other sites

Ok, after a bunch more creative digging I found this

http://us2.php.net/manual/en/function.mysqli-store-result.php

 

If you scroll down you get this

Beware when using stored procedures:

If you connect to the database and then call dbproc A followed by a call to db proc B and then close the connection to the db, the second procedure call will not work.

 

It looks like there is a bug in MYSQL or mysqli that returns an extra recordset than you would expect. It then doesn't let you call another stored procedure until you finish processing all the recordsets from the first stored procedure call.

 

The solution is to simply loop through the additional recordsets between calls to db procs. Here is a function that I call between db proc calls:

 

<?php

#--------------------------------

function ClearRecordsets($p_Result){

#--------------------------------

    $p_Result->free();   

    while($this->Mysqli->next_result()){

      if($l_result = $this->Mysqli->store_result()){

              $l_result->free();

      }

    }

}

 

?>

 

When I tried to use the function as is, I got an error about the $this, so I changed the function to

 

	#--------------------------------
function ClearRecordsets($p_Result, $p_mysqli){
#--------------------------------
	$p_Result->free();    
	while($p_mysqli->next_result()){
	  if($l_result = $p_mysqli->store_result()){
			  $l_result->free();
	  }
	}
}

 

Then changed my main code to this

	$mysqli = new mysqli("ip", "login", "pw", "db");

$result = $mysqli->query('CALL Proc_GetRegionInfo(10000001)');
$row = $result->fetch_assoc();
$regionName =  $row['regionName'];
ClearRecordsets($result, $mysqli);

$result = $mysqli->query('CALL Proc_GetFactionName(500007)');
$mysqli->store_result(); 
$row = $result->fetch_assoc();
$factionName =  $row['factionName'];
ClearRecordsets($result, $mysqli);

 

And now it works fine, just have to call that function after each stored proc call

Link to comment
https://forums.phpfreaks.com/topic/91124-stored-procedures/#findComment-467470
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.