在php调用hana数据库的一个sql时报错了,查表结构的sql:
select * from sys.table_columns where table_name = 'VBAP'
SQLSTATE[SL009]: <<Unknown error>>: 0 [unixODBC][Driver Manager]No columns were bound prior to calling SQLFetch or SQLFetchScroll (SQLFetchScroll[0] at /webserver/php74/src/ pdo_odbc/odbc_stmt.c:559)
经查,是 odb_stmt.c中这段代码的问题:
if (colsize < 256 && !S->going_long) {// ......
} else {// ......
}
改为如下:
if (1) {// ......
} else {// ......
}
然后重新编译pdo_odbc.so即可。
编译的方法是:
./configure --prefix=/usr/local/unixODBC --includedir=/usr/local/include --libdir=/usr/local/lib -bindir=/usr/local/bin --sysconfdir=/usr/local/etc --with-pdo-odbc=unixODBC,/usr/
然后
make && make install
这时,在pdo_odbc的modules目录下就编译出来了pdo_odbc.so ,
把这个so拷贝到php的extensions目录下,如果已经有旧的就覆盖 ,
然后重启 php-fpm,在我的环境中是这样的:
killall php-fpm
然后进入php-fpm可执行文件所在目录,执行:
./php-fpm
即可
现在再查这个sql就ok了: