PDO作用
    PDO(php data object)扩展类库为php访问数据库定义了轻量级的、一致性的接口,它提供了一个数据库访问抽象层,这样,无论你使用什么数据库,都可以通过一致的函数执行查询和获取数据,大大简化了数据库的捉拿和,并能够屏蔽不同数据库之间的差异,使用pdo可以很方便地进行跨数据库程序的开发,以及不同数据库间的移植,是将来php在数据库处理方面的主要发展方向,它可以支持mysql,postgresql,oracle,mssql等多种数据库

    PDO的安装
    1. 编辑php.ini文件:
    extension=php_pdo.dll
    extension=php_pdo_mysql.dll
    2.重启apache服务:
    httpd –k restart
    3.打开phpinfo.php查看是否有pdo
    image.png
    image.png

    创建PDO对象
    以多种方式调用构造方法
    image.png
    image.png
    PDO连接属性设置实例
    image.png
    第十课 - 图6%3B%0A%2F%2F#card=math&code=pdo-%3EsetAttribute%28PDO%3A%3AATTR_ERRMODE%2C%20PDO%3A%3AERRMODE_EXCEPTION%29%3B%0A%2F%2F&id=xJ9eZ)pdo->setAttribute(3,2);
    第十课 - 图7%3B%2F%2F#card=math&code=pdo-%3EsetAttribute%28PDO%3A%3AATTR_AUTOCOMMIT%2C0%29%3B%2F%2F&id=RZOVX)pdo->setAttribute(0,0);
    第十课 - 图8%3B%0A%2F%2F#card=math&code=pdo-%3EsetAttribute%28PDO%3A%3AATTR_DEFAULT_FETCH_MODE%2C%20PDO%3A%3AFETCH_ASSOC%29%3B%0A%2F%2F&id=pJR1C)pdo->setAttribute(19,2);

    echo “\nPDO是否关闭自动提交功能:
    “. $pdo->getAttribute(PDO::ATTR_AUTOCOMMIT);
    echo “\n当前PDO的错误处理的模式:
    “. $pdo->getAttribute(PDO::ATTR_ERRMODE);
    echo “\n表字段字符的大小写转换: “.
    $pdo->getAttribute(PDO::ATTR_CASE);
    echo “\n与连接状态相关特有信息: “.
    $pdo->getAttribute(PDO::ATTR_CONNECTION_STATUS);
    echo “\n空字符串转换为SQL的null:”. $pdo->getAttribute(PDO::ATTR_ORACLE_NULLS);
    echo “\n应用程序提前获取数据大小:pdo->getAttribute(PDO::ATTR_PERSISTENT);
    echo “\n与数据库特有的服务器信息:
    “.$pdo->getAttribute(PDO::ATTR_SERVER_INFO);
    echo “\n数据库服务器版本号信息:
    “. $pdo->getAttribute(PDO::ATTR_SERVER_VERSION);
    echo “\n数据库客户端版本号信息:
    “. $pdo->getAttribute(PDO::ATTR_CLIENT_VERSION);

    PDO连接设置字符集
    设置php连接mysql时的客户端字符串和连接字符串集为:
    第十课 - 图9%3B%0A%09%E6%88%96%E8%80%85%3A%0A#card=math&code=pdo-%3Eexec%28%E2%80%9Cset%20names%20utf8%E2%80%9D%29%3B%0A%09%E6%88%96%E8%80%85%3A%0A&height=24&id=bvogV)do->query(“set names utf8”);

    PDO对象中的成员方法

    1. query($sql); 用于执行查询SQL语句。返回PDOStatement对象
    2. exec($sql); 用于执行增、删、改操作,返回影响行数;
    3. getAttribute(); 获取一个”数据库连接对象”属性。
    4. setAttribute(); 设置一个”数据库连接对象”属性。
    5. beginTransaction 开启一个事物(做一个回滚点)
    6. commit 提交事务
    7. rollBack 事务回滚操作。
    8. errorCode 获取错误码
    9. errorInfo 获取错误信息
    10. lastInsertId 获取刚刚添加的主键值
    11. 创建SQL的预处理,返回PDOStatement对象
    12. 为sql字串添加单引号。

    PDO对预处理语句的支持
    PDOStatement对象的方法
    1、fetch() 返回结果集的下一行,结果指针下移,到头返回false 。
    参数: PDO::FETCH_BOTH (default)、:索引加关联数组模式
    PDO::FETCH_ASSOC、 :关联数组模式
    PDO::FETCH_NUM、 :索引数组模式
    PDO::FETCH_OBJ、 :对象模式
    PDO::FETCH_LAZY :所有模式(SQL语句和对象)
    2、fetchAll() 通过一次调用返回所有结果,结果是以数组形式保存
    参数: PDO::FETCH_BOTH (default)、
    PDO::FETCH_ASSOC、
    PDO::FETCH_NUM、
    PDO::FETCH_OBJ、
    PDO::FETCH_COLUMN表示取指定某一列
    如:$rslist = $stmt->fetchAll(PDO::FETCH_COLUMN,2);取第三列

    1. execute() 负责执行一个准备好了的预处理语句
    2. fetchColumn()返回结果集中下一行某个列的值
    3. setFetchMode()设置需要结果集合的类型
    4. rowCount() 返回使用增、删、改、查操作语句后受影响的行总数
    5. bindParam() 将参数绑定到相应的查询占位符上
      bool PDOStatement::bindParam ( mixed variable [, int $data_type [, int $length [, mixed $driver_options ]]] )
      其中:

    $parameter:占位符名或索引偏移量
    variable:参数的值,需要按引用传递也就是必须放一个变量
    $data_type:数据类型
    PDO::PARAM_BOOL PDO::PARAM_NULL
    PDO::PARAM_INT PDO::PARAM_STR
    PDO::PARAM_LOB PDO::PARAM_STMT
    PDO::PARAM_INPUT_OUTPUT
    $length:指数据类型的长度
    $driver_options:驱动选项。

    1. setAttribute()为一个预处理语句设置属性
    2. getAttribute()获取一个声明的属性
    3. errorCode() 获取错误码
    4. errorInfo() 获取错误信息
    5. bindColumn() 用来匹配列名和一个指定的变量名,这样每次获取各行记录时,会自动将相应的值赋给变量。
    6. bindValue() 将一值绑定到对应的一个参数中
    7. nextRowset() 检查下一行集
    8. columnCount() 在结果集中返回列的数目
    9. getColumnMeta() 在结果集中返回某一列的属性信息
    10. closeCursor() 关闭游标,使该声明再次执行

    准备语句
    得到pdo预处理对象的方法:
    $sql=“select * from user order by id”;
    $sth=$pdo->prepare($sql);
    以上代码中的$sth即为预处理对象
    在PDO中参数式的SQL语句有两种(预处理sql):
    1.insert into stu(id,name) value(?,?); //?号式(适合参数少的)
    2.insert into stu(id,name) value(:id,:name);//别名式(适合参数多的)

    PDO的事务处理
    事务:将多条sql操作(增删改)作为一个操作单元,要么都成
    功,要么都失败。
    MySQL对事务的支持:
    被操作的表必须是innoDB类型的表(支持事务)
    MySQL常用的表类型:MyISAM(非事务)增删改速度快、InnodB(事务型)安全性高
    更改表的类型为innoDB类型
    mysql> alter table stu engine=innodb;
    Query OK, 29 rows affected (0.34 sec)
    Records: 29 Duplicates: 0 Warnings: 0
    mysql> show create table stu\G; //查看表结构

    构建事务处理的应用程序
    开启一次事务:
    $pdo->beginTransaction();
    提交一次事务:
    $pdo->commit();
    回滚一次事务:
    $pdo->rollback();
    注意如下设置:
    1.$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0);
    2.$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1);