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

相关推荐

  1. 【SAP HANA 34】HANA查找函数LOCATE的使用

    2024-03-27 08:40:05       27 阅读
  2. 使用boost::hana::then的示例程序

    2024-03-27 08:40:05       56 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-27 08:40:05       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-27 08:40:05       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-27 08:40:05       87 阅读
  4. Python语言-面向对象

    2024-03-27 08:40:05       96 阅读

热门阅读

  1. linux 之 vi 的使用

    2024-03-27 08:40:05       39 阅读
  2. exec族

    exec族

    2024-03-27 08:40:05      40 阅读
  3. HikariCP入门

    2024-03-27 08:40:05       37 阅读
  4. Docker in Docker:揭秘原理,实战带你飞

    2024-03-27 08:40:05       37 阅读
  5. 精通c++系统编程

    2024-03-27 08:40:05       40 阅读
  6. JVM介绍

    JVM介绍

    2024-03-27 08:40:05      39 阅读