Hana数据库 No columns were bound prior to calling SQLFetch or SQLFetchScroll

在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了:

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值