无法通过php连接到informix数据库

时间:2014-07-08 17:20:50

标签: php database pdo informix

这是我到目前为止所做的............

为了将我的网站连接到informix数据库,我安装了Informix客户端SDK并通过Setnet32输入了服务器和主机信息,并且在通过ConnectTest演示测试时连接正常。

然后通过Windows中的ODBC数据源管理员创建了用户DSN和系统DSN并测试了连接。

现在我创建了一个如下所示的连接字符串:

$dbh = new PDO("odbc:Driver={IBM INFORMIX ODBC DRIVER};HOSTNAME=172.56.100.12;PORT=8056;DATABASE=eadmin;PROTOCOL=onsoctcp; UID=prsnl;PWD=prsnl;");

在这种情况下尝试登录时,我得到的错误如下:

  

PDOException: SQLSTATE[HY000] SQLDriverConnect: -11060 [Informix][Informix ODBC Driver]General error.

我尝试了另一个连接字符串,如下所示:

  

$dbh = new PDO("Dsn=bnm_info;Driver={IBM INFORMIX ODBC DRIVER};HOSTNAME=172.56.100.12;PORT=8056;DATABASE=eadmin;PROTOCOL=onsoctcp; UID=prsnl;PWD=prsnl;");

在这种情况下,我得到的错误如下:

PDOException: invalid data source name 

为了更清楚,访问数据库的代码如下:

$query = "select decrypt_char(passwd,'" . $_POST['passwd'] . "') from edak_users where userid='" . $_SESSION['username'] . "'";

$tt = $dbh->query($query);

$rs=$tt->fetch(PDO::FETCH_NUM);

请提出一个解决方案来帮助我,因为这个问题让我疯狂。

非常欢迎任何帮助。 感谢期待

3 个答案:

答案 0 :(得分:0)

示例#1使用odbc.ini的PDO_INFORMIX DSN示例

以下示例显示PDO_INFORMIX DSN用于连接到odbc.ini中编目为Infdrv33的Informix数据库:

<强>腓

$db = new PDO("informix:DSN=Infdrv33", "", "");
[ODBC Data Sources]
Infdrv33=INFORMIX 3.3 32-BIT

<强> ODBC.INI

[Infdrv33]
Driver=/opt/informix/csdk_2.81.UC1G2/lib/cli/iclis09b.so
Description=INFORMIX 3.3 32-BIT
Database=common_db
LogonID=testuser
pwd=testpass
Servername=ids_server
DB_LOCALE=en_US.819
OPTIMIZEAUTOCOMMIT=1
ENABLESCROLLABLECURSORS=1

示例#2使用连接字符串的PDO_INFORMIX DSN示例

以下示例显示使用Informix连接字符串语法连接到名为PDO_INFORMIX DSN的Informix数据库的common_db

$db = new PDO("informix:host=host.domain.com; service=9800;
    database=common_db; server=ids_server; protocol=onsoctcp;
    EnableScrollableCursors=1", "testuser", "tespass");

source

答案 1 :(得分:0)

您是否尝试过更简单的连接字符串:

$dbh = new PDO("DSN=bnm_info;UID=prsnl;PWD=prsnl;");

如果您使用Win64,还要确保在适当的odbcad32.exe中定义了DSN。有一个用于32位应用程序,另一个用于64位应用程序。

如果你的ODBC工作在odbcad32.exe,那么它应该可以使用这么简单的连接字符串。

答案 2 :(得分:0)

如果您尝试在Windows上运行此操作,请忘记odbc.ini,在Windows上将信息存储在注册表中。

初始-11060常规错误的原因是因为您缺少连接字符串中的关键参数(SERVER)

没有它(使用无DSN连接)

D:\Infx\PHP7\test>cat p2.php
<?php
$dbh = new PDO("odbc:Driver={IBM INFORMIX ODBC DRIVER};HOSTNAME=420ito;PORT=9088;DATABASE=sysmaster;PROTOCOL=onsoctcp;UID=informix;PWD=ximrofni;");
try
{
  $query = "select tabname from systables where tabid=99";
  $tt = $dbh->query($query);
  $rs=$tt->fetch(PDO::FETCH_NUM);
  print_r($rs);
}
catch (Exception $e)
{
  echo "*".$e->getMessage()."*";
}
?>


D:\Infx\PHP7\test>php p2.php
PHP Fatal error:  Uncaught PDOException: SQLSTATE[HY000] SQLDriverConnect: -11060 [Informix][Informix ODBC Driver]General error. in D:\Infx\PHP7\test\p2.php:2
Stack trace:
#0 D:\Infx\PHP7\test\p2.php(2): PDO->__construct('odbc:Driver={IB...')
#1 {main}
  thrown in D:\Infx\PHP7\test\p2.php on line 2

D:\Infx\PHP7\test>grep SERVER p2.php

现在,使用SERVER连接时没有错误:

D:\Infx\PHP7\test>grep SERVER p2.php
$dbh = new PDO("odbc:Driver={IBM INFORMIX ODBC DRIVER};SERVER=ids1210;HOSTNAME=420ito;PORT=9088;DATABASE=sysmaster;PROTOCOL=onsoctcp;UID=informix;PWD=ximrofni;");

D:\Infx\PHP7\test>php p2.php
Array
(
    [0] =>  VERSION
)

D:\Infx\PHP7\test>

SERVER应该是Informix服务器的名称(通常是INFORMIXSERVER环境变量的值)。

如果已将Informix服务器信息放入注册表中(使用setnet32),则无需在ODBC连接字符串中指定所有参数。 你可以这样做:

$dbh = new PDO("odbc:Driver={IBM INFORMIX ODBC DRIVER};SERVER=ids1210;DATABASE=sysmaster;UID=informix;PWD=ximrofni;");

驱动程序将从注册表中选择其余值。

此外,如前所述,如果您已经创建了ODBC DSN,则只能引用该DSN。像这样:

$dbh = new PDO("odbc:DSN=ids1210_32;UID=informix;PWD=ximrofni;");

请记住,如果您的PHP(模块)是64位,则需要创建64位ODBC DSN或使用“{IBM INFORMIX ODBC DRIVER(64-bit)}”作为驱动程序名称。你的dsn-less连接字符串。

如果您不想在注册表中存储任何内容,那么'DSN-less'选项(所有参数包括驱动程序名称)都很有用,但这取决于您使用哪个;)