ID: 20861 Updated by: [EMAIL PROTECTED] Reported By: [EMAIL PROTECTED] Status: Assigned Bug Type: Sybase-ct (ctlib) related Operating System: Linux PHP Version: 4.3.0RC2 Assigned To: thekid New Comment:
<?php /* Script to reproduce bug #20861 * * $Id$ */ ini_set('sybct.min_server_severity', 11); $db= sybase_connect('gurke', '******', '******'); sybase_select_db('tempdb', $db); // var_dump(sybase_query(' // create procedure test_bug // @input int // AS // BEGIN // set nocount on // // select @input 'result' // return 2 // END // ', $db)); // This doesn't print out the error message $q= sybase_query('test_bug 1', $db); while ($data= sybase_fetch_object($q)) { var_dump($q, $data); } // This actually prints out the warning message as // we have two resultsets $q= sybase_query(' declare @return int exec @return= test_bug 1 select @return ', $db); while ($data= sybase_fetch_object($q)) { var_dump($q, $data); } // var_dump(sybase_query('drop procedure test_bug', $db)); sybase_close($db); ?> Previous Comments: ------------------------------------------------------------------------ [2002-12-07 08:38:54] [EMAIL PROTECTED] Well, in earlier versions sybase_ct silently cancelled the unexpected results, now it will inform you it is doing so - I thought it was nice to be a bit more verbose about things. ------------------------------------------------------------------------ [2002-12-06 10:48:02] [EMAIL PROTECTED] After some more test, i can get the notice (notice -> no result) without "set nocount on". Don't have pushed further since the procedure involved is about 400 lines with call to others procedures. So, just to add that "set nocount on" is a case, not the only one, that trigger the error. ------------------------------------------------------------------------ [2002-12-06 09:53:00] [EMAIL PROTECTED] Test script : <? $sy = sybase_pconnect('DBHOST', 'user', 'pass'); sybase_select_db('MyDB', $sy); sybase_query("test_bug 1", $sy); ?> produce : Notice: sybase_query() [http://www.php.net/function.sybase-query]: Sybase: Unexpected results, cancelling current in - on line 4 with test_bug defined as follow : create procedure test_bug @input int AS BEGIN set nocount on select @input 'result' return 2 END Removing the "set nocount on" lead to expected result but, of course, in real wold sp, the nocount option is rarely used for fun... Build with Sybase ctclient v12.5 Works perfectly well with 4.2.3 and previous. ------------------------------------------------------------------------ -- Edit this bug report at http://bugs.php.net/?id=20861&edit=1