我有一个连接到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
我检查了文档,一切似乎都是正确的,所以我们尝试重新安装一切,没有运气。可能是什么问题?
答案 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端口来解决此问题。