Edit report at http://bugs.php.net/bug.php?id=48122&edit=1
ID: 48122
Comment by: theodoreb at goshen dot edu
Reported by: theodoreb at goshen dot edu
Summary: odbc_cursor() returns empty name
Status: Feedback
Type: Bug
Package: ODBC related
Operating System: Gentoo Linux
PHP Version: 5.2.9
Assigned To: kalle
Block user comment: N
Private report: N
New Comment:
patch failed to apply with the following error:
patching file php_odbc.c
Hunk #1 FAILED at 1470.
Hunk #2 succeeded at 1205 (offset -274 lines).
1 out of 2 hunks FAILED -- saving rejects to file php_odbc.c.rej
and from the php_odbc.c.rej file:
***************
*** 1470,1477 ****
if (max_len > 0) {
cursorname = emalloc(max_len + 1);
rc =
SQLGetCursorName(result->stmt,cursorname,(SQLSMALLINT)max_len,&len);
- if (rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO) {
- char state[6]; /* Not used */
SQLINTEGER error; /* Not used */
char errormsg[SQL_MAX_MESSAGE_LENGTH];
SQLSMALLINT errormsgsize; /* Not used */
--- 1470,1477 ----
if (max_len > 0) {
cursorname = emalloc(max_len + 1);
rc =
SQLGetCursorName(result->stmt,cursorname,(SQLSMALLINT)max_len,&len);
+ if ((rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO)
|| !cursorname) {
+ char state[6];
SQLINTEGER error; /* Not used */
char errormsg[SQL_MAX_MESSAGE_LENGTH];
SQLSMALLINT errormsgsize; /* Not used */
Previous Comments:
------------------------------------------------------------------------
[2011-01-17 16:50:34] [email protected]
Could you try the attached patch?
According to the ODBC specification available at MSDN, then its possible
for the SQLGetCursorName function to point to a NULL name where the
length and return codes still are correct, so if thats the case it would
fallback to the PHP cursor name which hopefully is the cause of this as
I'm unable to reproduce it
------------------------------------------------------------------------
[2011-01-17 16:48:41] [email protected]
The following patch has been added/updated:
Patch Name: odbc-bug-48122
Revision: 1295279320
URL:
http://bugs.php.net/patch-display.php?bug=48122&patch=odbc-bug-48122&revision=1295279320
------------------------------------------------------------------------
[2009-05-06 22:13:31] theodoreb at goshen dot edu
Thanks for responding.
I tried your code as follow:
error_reporting(E_ALL);
$conn = odbc_connect("mssql", "login", "passwd",SQL_CUR_USE_ODBC);
var_dump($conn, odbc_errormsg($conn));
$query = "SELECT * FROM tablename";
$cur = odbc_exec($conn,$query);
var_dump(odbc_errormsg($conn));
echo odbc_cursor($cur);
var_dump(odbc_errormsg($conn));
Here is the result:
resource(16) of type (odbc link) string(0) "" string(0) "" string(0) ""
------------------------------------------------------------------------
[2009-05-06 21:37:31] [email protected]
Try this:
<?php
error_reporting(E_ALL);
$conn = odbc_connect("mssql", "login", "passwd",SQL_CUR_USE_ODBC);
var_dump($conn, odbc_errormsg($conn));
$query = "SELECT * FROM tablename";
$cur = odbc_exec($conn,$query);
var_dump(odbc_errormsg($conn));
echo odbc_cursor($cur);
var_dump(odbc_errormsg($conn));
?>
------------------------------------------------------------------------
[2009-04-30 16:08:45] theodoreb at goshen dot edu
Description:
------------
odbc_cursor() returns empty string when the connection is created using
odbc_connect() with SQL_CUR_USE_ODBC as the fourth parameter.
Using unixODBC-2.2.12 and freetds-0.82-r2 to connect to Microsoft SQL
Server 2008.
Reproduce code:
---------------
$conn = odbc_connect("mssql", "login", "passwd",SQL_CUR_USE_ODBC);
$query = "SELECT *
FROM tablename";
$cur = odbc_exec($conn,$query);
echo odbc_cursor($cur);
Expected result:
----------------
cursor name of $cur, something like SQL_CURa70b90
Actual result:
--------------
empty string ''
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/bug.php?id=48122&edit=1