* 1. PDO是PHP与其它数据库之间的中间层,或者抽象层
* 2. PDO屏蔽了各个数据库之间的差异,对PHP提供了一个统一的访问接口
* 3. 使用PDO的第一步就是生成一个PDO对象,所有的功能必须要用这个对象来调用
* 4. 成功返回PDO对象,失败抛出异常
//1.配置参数
* DNS:数据源
* 基本格式: 数据库类型:属性1:值1; 属性2:值2;...
* 类型:如mysqli,oracle等
* 属性: 主机,默认数据库,默认字符集,默认端口号
* 例如: mysql:host=127.0.0.1;dbname=php;charset=utf8;port=3306;
1 | $dsn = 'mysql:host=localhost; dbname=php; charset=utf8; port=3306'; |
//数据库用户名
1 | $userName = 'root'; |
//数据库用户密码
1 | $password = 'root'; |
//配置连接属性
1 2 3 4 5 6 | $options = [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, //设置错误模式 PDO::ATTR_CASE => PDO::CASE_NATURAL, //数据表字段保持不变 PDO::ATTR_EMULATE_PREPARES => true, //启用PDO模拟 PDO::ATTR_PERSISTENT => true, //启用持久性连接 ]; |
//使用try-catch()来捕获可能发生的错误
1 2 3 4 5 6 7 8 | try { //调用PDO构造函数实例化PDO类,创建PDO对象 $pdo = new PDO($dsn, $userName, $password, $options); //连接是所有操作的基础,无论你设置的错误模式级别是什么,都会强制使用EXCEPTION异常模式 } catch (PDOException $e) { print 'Connect ERROR!:'.$e->getMessage(); //推荐使用英文提示,以防止页面中文乱码 die(); //连接错误是致命错误,必须停止脚本的执行 } |
//断开PDO连接
1 | $pdo = null; |
//销毁PDO对象
1 | unset($pdo); |
//更多的时候,可以使用简写:
1 | $pdo = new PDO('mysql:dbname=php;','root', 'root'); //其它参数取默认值 |
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) | 黑马程序员IT技术论坛 X3.2 |