PHP PDO sqlsrv未定义的类常量SQLSRV_ENCODING_UTF8

时间:2016-06-16 22:27:58

标签: php codeigniter pdo sql-server-2012 xampp

我有一个连接到SQL Server 2008数据库的Codeigniter 3应用程序。我们使用Windows server 2012 r2 64bit,SQL Server Express 2012和xampp以及php 5.6设置了一个新的vm。

我们将应用程序移动到它,安装了MSODBC并将pdo_sqlsrv版本3.2 dll添加到extensions文件夹并将其加载到ini文件中,但是当我们启动应用程序时,我们收到了以下错误消息:

Undefined class constant SQLSRV_ENCODING_UTF8 in pdo_sqlsrv_driver.php on line 144

我检查了文档,一切似乎都是正确的,所以我们尝试重新安装一切,没有运气。可能是什么问题?

2 个答案:

答案 0 :(得分:0)

您的PHP安装中可能有错误的PDO驱动程序。我在几台Windows服务器上运行PHP / CodeIgniter,并在最初设置时遇到了错误驱动程序的问题。

由于您使用的是PHP 5.6,因此需要确保 php_pdo_sqlsrv_56_ts.dll php_pdo_sqlsrv_56_nts.dll 驱动程序位于PHP android:layout_height="match_parent"目录中。然后,在/ext/文件中,您需要确保取消注释这两个扩展程序:

  

延长= php_sqlsrv_56_nts.dll
  延长= php_pdo_sqlsrv_56_nts.dll

取消注释这两个后,请确保注释掉对SQL Server驱动程序的其他引用。如果这没有帮助,请查看另一篇文章:Xampp MS SQL server PHP 5.6

调整php.ini文件后,请记住通过IIS重启网站。

答案 1 :(得分:0)

对于正在寻找此错误解决方案的人们,我通过在SQL Server配置管理器中指定默认的TCP端口来解决此问题。