pdo的环境配置:开启支持pdo 在php.ini配置文件中开启:extension=php_pdo.dllextension=php_pdo_mysql.dll在pdo操作中涉及到类:pdo、pdostatement(预处理对象)、pdoexception(异常类)一、 pdo类的构造方法:-------------------------------------------
pdo的环境配置:开启支持pdo 在php.ini配置文件中开启: extension=php_pdo.dll extension=php_pdo_mysql.dll 在pdo操作中涉及到类:pdo、pdostatement(预处理对象)、pdoexception(异常类)一、 pdo类的构造方法:--------------------------------------------------------- pdo __construct( string dsn [, string username [, string password [, array driver_options]]] ); 其中:dsn数据库连接信息如“mysql:host=localhost;dbname=库名” dsn的格式:”驱动名:host=主机名;dbname=库名“ username:用户名 password:密码 driver_options:配置选项: 如: pdo::attr_persistent=>true,是否开启持久链接 *pdo::attr_errmode=>错误处理模式:(可以是以下三个)(3) pdo::errmode_silent:不报错误(忽略)(0) pdo::errmode_warning:以警告的方式报错(1) *pdo::errmode_exception:以异常的方式报错(推荐使用)。(2)$pdo = new pdo(mysql:host=localhost;dbname=lamp36db,root,root);$pdo->setattribute(pdo::attr_errmode,pdo::errmode_exception);其他方法:--------------------------------------------------------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.prepare 创建sql的预处理,返回pdostatement对象12.quote 为sql字串添加单引号。预处理对象pdostatement对象:=============================================我们可以通过pdo的方法来获取pdostatement: 1.pdo的query(查询sql)方法获取,用于解析结果集 2.pdo的prepare(sql)方法获取,用于处理参数式sql并执行操作。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);取第三列3、execute() 负责执行一个准备好了的预处理语句 4. fetchcolumn()返回结果集中下一行某个列的值5. setfetchmode()设置需要结果集合的类型6. rowcount() 返回使用增、删、改、查操作语句后受影响的行总数7. setattribute()为一个预处理语句设置属性8. getattribute()获取一个声明的属性9. errorcode() 获取错误码10. errorinfo() 获取错误信息11. bindparam() 将参数绑定到相应的查询占位符上 bool pdostatement::bindparam ( mixed $parameter , 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:驱动选项。12. bindcolumn() 用来匹配列名和一个指定的变量名,这样每次获取各行记录时,会自动将相应的值赋给变量。13. bindvalue() 将一值绑定到对应的一个参数中14. nextrowset() 检查下一行集15. columncount() 在结果集中返回列的数目16. getcolumnmeta() 在结果集中返回某一列的属性信息17. closecursor() 关闭游标,使该声明再次执行在pdo中参数式的sql语句有两种(预处理sql): 1.insert into stu(id,name) value(?,?); //?号式(适合参数少的) 2.insert into stu(id,name) value(:id,:name); // 别名式(适合参数多的)在pdo中为参数式sql语句赋值有三种: 1.使用数组 $stmt->execute(array(lamp1404,qq2)); $stmt->execute(array(id=>lamp1404,name=>qq2)); 2.使用方法单个赋值 $stmt->bindvalue(1,lamp1901); $stmt->bindvalue(2,qq2); $stmt->execute(); $stmt->bindvalue(:id,lamp1901,pdo::param_str); //带指定类型 $stmt->bindvalue(:name,qq2,pdo::param_str); $stmt->execute(); 3. 使用方法绑定变量 $stmt->bindparam(:id,$id); $stmt->bindparam(:name,$name); $id=lamp1401; $name=qq2; $stmt->execute(); 事务处理----------------------------------------------- 事务:将多条sql操作(增删改)作为一个操作单元,要么都成功,要么都失败。(如果一次插入多条数据,一条执行失败,数据回滚,全部删除)----- 4. pdo对事务的支持 第一:被操作的表必须是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就可以操作数据库了 使用到了pdo中的方法: begintransaction 开启一个事物(做一个回滚点) commit 提交事务 rollback 事务回滚操作。 使用情况:当做多条sql语句处理时(增删改),要求是都必须成功。
