Linux下thinkPHP连接数据库报如下错:PDOException in Connection.php line 295(SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' (using password: YES))

今天测试了一个tlinkphp的程序,不知道咋地了,始终就是不能连接数据库,很是悲剧,具体请看;

SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' (using password: YES)

  1. $this->fetchType = $config['result_type'];
  2. }
  3. try {
  4. if (empty($config['dsn'])) {
  5. $config['dsn'] = $this->parseDsn($config);
  6. }
  7. if ($config['debug']) {
  8. $startTime = microtime(true);
  9. }
  10. $this->links[$linkNum] = new PDO($config['dsn'], $config['username'], $config['password'], $params);
  11. if ($config['debug']) {
  12. // 记录数据库连接信息
  13. Log::record('[ DB ] CONNECT:[ UseTime:' . number_format(microtime(true) - $startTime, 6) . 's ] ' . $config['dsn'], 'sql');
  14. }
  15. } catch (\PDOException $e) {
  16. if ($autoConnection) {
  17. Log::record($e->getMessage(), 'error');
  18. return $this->connect($autoConnection, $linkNum);

这种错误,基本属于数据库连接不正常所导致的,那必须要看一下数据库连接文件,有些时候不是单一的一个数据库文件,可能会是多个,多个的时候可能就会显示这样;具体的请参阅忘记mysql数据库root用户密码的解决办法要么就卸载重装数据库Windows下如何干净利索的完全卸载Mysql以及 mysql8.0如何在windows 10 (win10)下卸载干净具体多样化的东西,都需要根据多方面的参考才可以,还有一种说辞的,具体请看下面的说法;

本地的数据库的密码默认是 root 导致(比如:phpstudy),到时候更改密码测试一下,这个问题有待确认,不能说就能解决;

还有其他一种比较靠谱的:

找了N多方法来尝试,重装apache、mysql。安装集成软件都试过了。错误一样。

后来细细分析,PDOException in Connection指的不就是PDO异常吗?

然后去了解了一些PDO的知识,找到了问题原因。

然后默默的去php.ini中找到

extension=php_pdo.dll
extension=php_pdo_sqlite.dll

将这两句去掉前面的分号;

php7.0以上是这两句

extension=pdo
extension=pdo_mysql

然后重启apache ok搞定;

PS:延伸阅读;(下面阐述的一个问题点,多数适合windows系统)

需要从微软下载sqlserver关于php的驱动,然后把dll文件放到本地php的ext目录,然后需要把文件名添加到php.ini中,注意、注意、注意:这里边是两个文件:
extension=php_sqlsrv.dll
extension=php_pdo_sqlsrv.dll
一个带有pdo,一个不带,tp5默认都是pdo链接方式,故请确认下是否已添加extension扩展,这个加好后,基本就不会报这个错了

我这个问题是啥问题呢?在tlinkphp根目录下也会有其他的文件,文件不一,具体请看;

比如上面的图片中,几个无后缀的文件,就可能写入着各种数据库连接信息或者其他全局信息,所以看待问题,要多种的选择才可以;比如我这里就是 修改.env 中的数据库账号密码 才可以打开;

 

所写所说,是心之所感,思之所悟,行之所得;文当无敷衍,落笔求简洁。 以所舍,求所获;有所依,方所成!

更多请关注:老梁`s Blog

免责声明,若由于商用引起版权纠纷,一切责任均由使用者承担。 您必须遵守我们的协议,如果您下载了该资源行为将被视为对《免责声明》全部内容的认可->联系老梁投诉资源
Laoliang.Net资源全部来自互联网收集,仅供用于学习和交流,请勿用于商业用途。如有侵权、不妥之处,请联系站长并出示版权证明以便删除。 敬请谅解! 侵权删帖/违法举报/投稿等事物联系邮箱:service@laoliang.net
老梁`s Blog(老梁博客) » Linux下thinkPHP连接数据库报如下错:PDOException in Connection.php line 295(SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' (using password: YES))

发表评论

本站承接,网站推广(SEM,SEO),软件的安装的安装与调试,服务器的推荐以及配置,APP的开发与维护,网络或者web维护;财务软件,客户管理系统,人力资源,超市POS,医药管理,服务器安全,ecshop,金蝶,用友,管家婆;

立即查看 了解详情