这是我到目前为止所做的............
为了将我的网站连接到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);
请提出一个解决方案来帮助我,因为这个问题让我疯狂。
非常欢迎任何帮助。 感谢期待
答案 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");
答案 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'选项(所有参数包括驱动程序名称)都很有用,但这取决于您使用哪个;)