linux php 1045,Linux下thinkPHP连接数据库报如下错:PDOException in Connection.php line 295(SQLSTATE[HY000] [1045...

$this->fetchType=$config['result_type'];

}

try {

if (empty($config['dsn'])) {

$config['dsn'] =$this->parseDsn($config);

}

if ($config['debug']) {

$startTime=microtime(true);

}

$this->links[$linkNum] = newPDO($config['dsn'],$config['username'],$config['password'],$params);

if ($config['debug']) {

// 记录数据库连接信息

Log::record('[ DB ] CONNECT:[ UseTime:' .number_format(microtime(true) -$startTime, 6) . 's ] ' .$config['dsn'], 'sql');

}

} catch (\PDOException$e) {

if ($autoConnection) {

Log::record($e->getMessage(), 'error');

return$this->connect($autoConnection,$linkNum);

c238eda5106b149ae7b6210aa6db02f0.png

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

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

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

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

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

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

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

extension=php_pdo.dllextension=php_pdo_sqlite.dll

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

php7.0以上是这两句

extension=pdoextension=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根目录下也会有其他的文件,文件不一,具体请看;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值