PHP PDO:Charset = UTF8:在dsn字符串中指定了无效的关键字字符集

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了PHP PDO:Charset = UTF8:在dsn字符串中指定了无效的关键字字符集脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
我使用sqlsrv驱动程序连接到带有PDO的MS sql服务器.

PHP版本是5.3.24.
工作连接如下所示:

$dsny = "sqlsrv:Server=xx1;Database=xx2";
$usery = 'xx3';
$passwordy = 'xx4';
$dbhy = new PDO($dsny,$usery,$passwordy);

**

但我需要设置字符,然后我尝试这个:

$dsny = "sqlsrv:Server=xx1;Database=xx2;charset=utf8";
$usery = 'xx3';
$passwordy = 'xx4';
$dbhy = new PDO($dsny,$passwordy);

当我添加charset时,我收到此错误
“致命错误:带有消息’sqlstatE [IMSSP]的未捕获异常’PDFException’:在dsn字符串’中指定了无效关键字’charset’

那可能导致这个错误原因是什么

从我读到的我需要这样做,因为我正在运行一个新的@L_406_11@版本.

解决方法

您需要在连接后应用该属性

$dbhy->setattribute(PDO::sqlSRV_ATTR_ENCODING,PDO::sqlSRV_ENCODING_UTF8);

见:https://msdn.microsoft.com/en-us/library/ff628157(v=sql.105).aspx

脚本宝典总结

以上是脚本宝典为你收集整理的PHP PDO:Charset = UTF8:在dsn字符串中指定了无效的关键字字符集全部内容,希望文章能够帮你解决PHP PDO:Charset = UTF8:在dsn字符串中指定了无效的关键字字符集所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。