PHP面向对象(七)

PHP操作MySQL数据库方式有三种:
  1. mysql 最原始的、纯过程化的 如连接: mysql_connect(主机名,账号,密码);
    mysql_query();

  2. mysqli 改进版的、兼容过程化和面向对象化操作
    如:连接: mysqli_connect(主机名,账号,密码,库名) //过程化
    new mysqli(主机名,账号,密码,库名) //面向对象

  3. PDO 通用的,兼容其他数据库 , 纯面向对象方式
    如: 连接: new PDO(DSN,账号,密码);

  选择PDO的原因(优点):
    1> 跨数据库
    2> 带预处理(防sql注入)
    3> 支持事务操作

  PDO(php data object)扩展类库为php访问数据库定义了轻量级的、一致性的接口,它提供了一个数据库访问抽象层,这样,无论你使用什么数据库,都可以通过一致的函数执行查询和获取数据,大大简化了数据库的捉拿和,并能够屏蔽不同数据库之间的差异,使用pdo可以很方便地进行跨数据库程序的开发,以及不同数据库间的移植,它可以支持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

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对象:
  $pdo = new PDO("mysql:host=localhost;dbname=LAMP","root","123456");
设置php连接mysql时的客户端字符串和连接字符串集为:
  $pdo->exec("set names utf8");
  或者:
  $pdo->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.prepare 创建SQL的预处理,返回PDOStatement对象
  12.quote 为sql字串添加单引号。

PDO对预处理语句的支持:
  PDO提供了一种名为预处理语句(Prepared Statement)的机制。它可以将整个SQL命令向数据库服务器发送一次,以后只要参数发生变化,数据库服务器只需要对命令的结构做一次分析就够了,即编译一次,可以多次执行。不仅可以有效的提高命令的处理效率,还能有效防止SQL注入。(MySQL数据库本身就支持预处理机制,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);取第三列
  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() 关闭游标,使该声明再次执行

 1 <?php
 2     require ‘./config.php‘;
 3 try {
 4     $pdo=new PDO(DSN,USER,PASS);
 5     $pdo->query("set names utf8");
 6 } catch (PDOException $e) {
 7     echo "连接数据库失败!原因:".$e->getMessage();
 8     die;
 9 }
10
11
12     $stmt=$pdo->query("select * from stu");
13
14     //第一种解析方式    直接循环对象
15 /*    foreach ($stmt as $stu) {
16         echo $stu[‘id‘].":".$stu[‘name‘]."<br>";
17     }*/
18
19     //第二种    一次拿出所有数据
20     /*$list=$stmt->fetchAll(PDO::FETCH_ASSOC);
21     var_dump($list);*/
22
23     //第三种    一次拿一条数据
24     while ($row=$stmt->fetch(PDO::FETCH_ASSOC)) {
25         var_dump($row);
26     }
27 ?>

在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("LAMP","qq2"));
    $stmt->execute(array("id"=>"LAMP","name"=>"qq2"));
  2.使用方法单个赋值
    $stmt->bindValue(1,"LAMP");
    $stmt->bindValue(2,"qq2");
    $stmt->execute();

    $stmt->bindValue(":id","LAMP",PDO::PARAM_STR); //带指定类型
    $stmt->bindValue(":name","qq2",PDO::PARAM_STR);
    $stmt->execute();

  3. 使用方法绑定变量
    $stmt->bindParam(":id",$id);
    $stmt->bindParam(":name",$name);
    $id="LAMP";
    $name="qq2";
    $stmt->execute();

 1 <?php
 2 //PDO操作
 3 require ‘./config.php‘;
 4
 5 try {
 6
 7     $driver=array(PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION);
 8     $pdo=new PDO(DSN,USER,PASS,$driver);
 9
10 } catch (Exception $e) {
11     die("PDO实例化失败!原因:".$e->getMessage());
12 }
13
14 try {
15     //别名式
16     $sql="insert into stu values(null,:name,:sex,:age,:classid)";
17     //?号式
18     //$sql="insert into stu values(null,?,?,?,?)";
19     $stmt=$pdo->prepare($sql);
20
21     //可以无序
22     $data=array(
23             array("name"=>"pp04","sex"=>"w","age"=>22,"classid"=>"lamp149"),
24             array("sex"=>"m","name"=>"pp05","age"=>20,"classid"=>"lamp145"),
25             array("name"=>"pp01","sex"=>"w","age"=>22,"classid"=>"lamp150"),
26         );
27
28     //?号式,注意顺序
29     /* $data=array(
30             array("pp09","w","22","lamp145"),
31             array("pp07","m","20","lamp149"),
32             array("pp08","w","22","lamp149"),
33         );*/
34     $m=0;
35     foreach ($data as $v) {
36         $stmt->execute($v);
37         $m+=$stmt->rowCount();
38     }
39 } catch (Exception $e) {
40     echo "添加失败!原因:".$e->getMessage()."<br>";
41 }
42     echo "成功添加{$m}条!";
43
44 ?> 

MySQL的事务处理:
  事务:将多条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就可以操作数据库了
      使用到了PDO中的方法:
        beginTransaction 开启一个事物(做一个回滚点)
        commit 提交事务
        rollBack 事务回滚操作。

    使用情况:当做多条sql语句处理时(增删改),要求是都必须成功。

  开启一次事务:
    $pdo->beginTransaction();
  提交一次事务:
    $pdo->commit();
  回滚一次事务:
    $pdo->rollback();
  注意如下设置:
    1.$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0);
    2.$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1);

 1 <?php
 2
 3 require ‘./config.php‘;
 4
 5 try {
 6     $pdo=new PDO(DSN,USER,PASS);
 7     //设置异常模式[默认情况下SQL执行失败忽略]
 8     $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
 9 } catch (Exception $e) {
10     die("PDO实例化失败!原因:".$e->getMessage());
11 }
12
13 try {
14     //开启事务
15     $pdo->beginTransaction();
16
17     $sql="insert into stu values(null,?,?,?,?)";
18     $stmt=$pdo->prepare($sql);
19
20     $data=array(
21             array("pp09","w","22","lamp145"),
22             array("pp10","m","20","lamp149"),
23             array("pp08","w","22","lamp149"),
24         );
25     $m=0;
26     foreach ($data as $v) {
27         $stmt->execute($v);
28         $m+=$stmt->rowCount();
29     }
30     //如果前面都没有异常说明SQL全部执行成功,提交事务
31     $pdo->commit();
32 } catch (Exception $e) {
33     echo "添加失败!原因:".$e->getMessage();
34     //捕获到异常,执行回滚
35     $pdo->rollback();
36     $m=0;
37 }
38 echo "成功添加{$m}条数据";
39 ?>    
时间: 2024-08-24 06:33:28

PHP面向对象(七)的相关文章

疯狂java学习笔记之面向对象(七) - super关键字

super有以下两大作用: 1.起限定作用:强制去访问父类的成员(Field.方法) 2.起调用作用:指定/显示调用父类的某个构造器 super调用规则: 1.子类构造器总会调用父类构造器一次,默认情况下子类构造器会自动调用父类无参数的构造器; 2.若希望明确指定子类构造器调用父类哪个构造器,可以用super(参数,参数,....),到底调用哪个父类构造器取决于super后面传入的形参列表; 3.this()调用与super()调用都必须出现在构造器的第一行,所以他们两个调用时不能同时出现的.

pyhon学习目录

pyhon学习目录 目录 一.计算机基础 二.python基础 三.函数 四.常用模块 五.模块和包 六.面向对象 七.网络编程和并发编程 八.数据库 九.前端 十.python web框架 十一.Git版本控制 十二.爬虫 十三.前端框架vue 十四.量化投资和python 十五.算法基础 十六.设计模式 十七.restful framework 十八.linux基础 二十.rbac权限管理 二十一.cmdb系统 二十二.crm系统 原文地址:https://www.cnblogs.com/x

sdut 面向对象程序设计上机练习七(类和对象)

面向对象程序设计上机练习七(类和对象) Time Limit: 1000MS Memory limit: 65536K 题目描述 利用类的数据成员和成员函数完成下列操作:输入三个整数,输出它们的最大值. 输入 输入三个整数. 输出 输出3个整数的最大值. 示例输入 2 8 5 示例输出 8 这个就不做详细注释了,初学者也能尝试着看懂. #include <iostream> using namespace std; class shu { private: int a,b,c; public:

java面向对象编程(七)--四大特征之多态

1.多态概念 多态性是对象多种表现形式的体现.比如我们说"宠物"这个对象,它就有很多不同的表达或实现,比如有小猫.小狗.蜥蜴等等.那么我到宠物店说"请给我一只宠物",服务员给我小猫.小狗或者蜥蜴都可以,我们就说"宠物"这个对象就具备多态性. java中的多态,就是指一个引用(类型)在不同情况下的多种状态.也可以理解成,多态是指通过指向父类的指针,来调用在不同子类中实现的方法.也可以理解为"一个接口,多个方法". 实现多态有两种

Python基础-第七天-面向对象编程进阶和Socket编程简介

本篇内容: 1.面向对象编程进阶-静态方法 2.面向对象编程进阶-类方法 3.面向对象编程进阶-属性方法 4.面向对象编程进阶-特殊成员(内置方法) 5.面向对象编程进阶-反射 6.异常处理.断言 7.Socket编程简介 一.面向对象编程进阶-静态方法 1.静态方法的实现 通过@staticmethod装饰器可以把其装饰的方法变为一个静态方法: 变成静态方法后,形参中可以不用写self了.如果写了self,默认是不会把对象本身传递给self,需要手动传递: class Dog(object):

面向对象的七个设计原则

一.单一职责原则 一个类,最好只做一件事,只有一个引起它的变化.单一职责原则可以看做是低耦合.高内聚在面向对象原则上的引申, 将职责定义为引起变化的原因,以提高内聚性来减少引起变化的原因.职责过多,可能引起它变化的原因就越多,这将 导致职责依赖,相互之间就产生影响,从而大大损伤其内聚性和耦合度.通常意义下的单一职责,就是指只有一种单一 功能,不要为类实现过多的功能点,以保证实体只有一个引起它变化的原因.专注,是一个人优良的品质:同样的,单 一也是一个类的优良设计.交杂不清的职责将使得代码看起来特

细说php(七) 面向对象编程

一.类的声明与对象初始化 1.1 在类中声明成员属性时: 前面必须有修饰词, 当不知道使用那个时, 就使用var, 如果知道使用那一个修饰关键字, 就不使用var了 var $color; var $name = "zhangsan" 1.2 一个文件只保存一个类, 文件名中包含类名, 如:类名.class.php person.class.php 1.3 使用new关键字来创建对象, 创建了一个对象就在内存中分配一个空间 $对象引用 = new 类名; $person = new P

面向对象的七种基本设计原则

面向对象的7种基本设计原则: 里氏替换原则单一职责原则依赖倒置原则接口隔离原则开放关闭原则迪米特法则(最少知道原则)合成复用原则 面向对象的3个基本要素:封装.继承.多态 1.里氏替换原则(Liskov-Substituion Principle) 核心思想为:子类可以替代父类出现的位置,而整个软件系统功能没有影响. 这一思想体现为对继承机制的约束规范,只有子类能够替换基类时,才能保证系统在运行期内识别子类,这是保证继承复用的基础.同时,这一约束反过来则是不成立的,子类可以替换基类,但是基类不一

第七章、面向对象分析

第七章.面向对象分析1.分析类,可划分为实体类.边界类和控制类种类型.  a.实体类:表示系统储存和管理的永久信息.  b.边界类:表示参与者与系统之间的交互.  c.控制类:表示系统在运行过程中的业务控制逻辑.2.面向对象的思想主要包括:   继承 多态 封装          封装:用抽象的数据类型将数据和基于数据的操作封装在一起,数据被保护在抽象数据类型内部.   继承:子类拥有父类的所有数据和操作.        多态:一个程序中同名的不同方法共存的情况.      有两种形式的多态–