温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

PDO连接出错怎么办

发布时间:2021-03-05 13:38:21 来源:亿速云 阅读:233 作者:小新 栏目:编程语言

小编给大家分享一下PDO连接出错怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

 1.确认PDO开启

   PDO的开启必须在Windows环境下php 5.1以上版本中。

在自己的环境内新建 test.php文件,内容如下:

<?php
 print phpinfo();
?>

运行后能看见下图,便说明已经开启成功,直接转至2。

PDO连接出错怎么办

若无法运行则打开php.ini配置文件,找到extension=php_pdo.dll(配置php配置文件,开启相应扩展) 和extension=php_pdo_mysql.dll (开启对相应数据库的扩展,以MySQL为例),去掉前面“;”的注释,修改后的两行配置内容如下:

extension=php_pdo.dll
extension=php_pdo_mysql.dll

完成后重启apache后即可。

 2.数据库连接问题

  1. 连接到 MySQL

<?php
   $dbh = new PDO('mysql:host=localhost;dbname=my_database', $user, $pass);
?>

注意:如果有任何连接错误,将抛出一个 PDOException 异常对象。

b.处理连接错误

<?phptry {
    $dbh = new PDO('mysql:host=localhost;dbname=my_database', $user, $pass);
    foreach($dbh->query('SELECT * from student') as $row) {
        print_r($row);
    }
    $dbh = null;} catch (PDOException $e) {
    print "Error!: " . $e->getMessage() . "<br/>";
    die();}
?>

3.SQL语句本身有错误

<?php
//实例化PDO对象
$pdo = new PDO('mysql:host=localhost;port=3306;dbname=my_database','root','root');

//写操作
$sql = "delete from student";		//错误SQL
$rows = $pdo->exec($sql);

//错误判定:exec方法执行结果成功也存在返回0的情况,错误会返回false,所以要判定是否是SQL错误,需要判定结果为false
if(false === $rows){
    //取出错误细信息
    echo 'SQL错误:<br/>';
    echo '错误代码为:' . $pdo->errorCode() . '<br/>';   
    echo '错误原因为:' . $pdo->errorInfo()[2];		
    //errorInfo返回数组,2下标代表错误具体信息          
    exit;		                                    
    //错误不需要继续执行代码
}
?>

语句问题可以通过连接数据库,通过cmd命令行或者数据库可视化软件(例如Navicat、phpMyAdmin)确认语句问题。

以上是“PDO连接出错怎么办”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

pdo
AI