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 =  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语句处理时(增删改),要求是都必须成功。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • pdo类PDO是一个“数据库访问抽象层”,作用是统一各种数据库的访问接口,与mysql和mysqli的函数库相比,...
    桖辶殇阅读 852评论 0 0
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,560评论 18 399
  • JDBC简介 SUN公司为了简化、统一对数据库的操作,定义了一套Java操作数据库的规范,称之为JDBC。JDBC...
    奋斗的老王阅读 1,504评论 0 51
  • 本节介绍Statement接口及其子类PreparedStatement和CallableStatement。 它...
    zlb阅读 1,132评论 0 0
  • 1 十一月份,我在一个群里听到两三位资深书评人说美国宅男斯蒂芬.盖斯写的《微习惯》很不错,于是我就果断入手了。 很...
    灵林玖玖阅读 6,760评论 221 339