pdo php utf8,PHP PDO sqlsrv未定义的类常量SQLSRV_ENCODING_UTF8

我有一个连接到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

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

解决方法:

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

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

extension=php_sqlsrv_56_nts.dll

extension=php_pdo_sqlsrv_56_nts.dll

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

调整php.ini文件后,请记住通过IIS重新启动站点.

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

来源: https://codeday.me/bug/20190711/1430632.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值