php+pdo方法详解,PHP PDO mysql抽象层

使用PDO构造函数连接数据库及DSN详解

$dbms = 'MysqL';$dbname = 'test'$user = 'root'$pwd = '123456'$host = 'localhost'$dsn = "$dbms:host=$host;dbName=$dbname";try{$pdo = new PDO($dsn,$user,1)">$pwd);echo 'pdo连接数据库成功';

}catch(Exception $e){echo $e->getMessage().'
';

}

页面输出的结果如下图:

pdo连接数据库成功

由于数据库服务器只是特定的端口上监听连接请求。每种数据库服务器具有一个默认的端口号(MysqL 是3306),但是数据库管理员可以对端口号进行修改,因此有可能 PHP找不到数据库的端口号,此时就可以在 DSN中包含端口号。比如:

$dsn="MysqL:host=127.0.0.1;port=3306;dbname=admin";

PDO中获取结果集之fetch()方法详解

首先创建一个PHP文件,通过 PDO连接MysqL数据库,然后定义 SELECT查询语句,应用prepare()和execute()方法执行查询操作,接着,通过fetch()方法返回结果集中下一行数据没同事设置结果集以关联数组形式返回,最后通过 while语句完成数据的循环输出,具体代码如下:

$host;dbname={);$query = "SELECT * FROM user";$res = $pdo->prepare($query$res->execute();while($result = $res->fetch(PDO::FETCH_ASSOC)){$result['username'].' '.$result['password'].' '.$result['email'].'
';

}

};

}

PDO中获取结果集之fetchAll()方法详解

execute();$res->fetchAll(PDO::FETCH_ASSOC);for($i=0;$i';

}

};

}

PDO中获取结果集之fetchColumn()方法详解

$query = "select * from user"$res->fetchColumn(0).'
';//返回id

$res->fetchColumn(0).'
';;

}

PDO中执行sql语句的三种方法

第一种方法:exec()方法

该方法返回执行sql 语句时受影响的行数,通常用于 INSERT,DELETE和UPDATE语句中。

$query = "INSERT INTO user(username,password,confirm,email) VALUES('cyy01','123','965794175@qq.com')"$pdo->exec(echo '插入成功,受影响的行数为:'.$res;

}

第二种方法:query()方法

query()方法用于返回执行查询后的结果集

$pdo->query(print_r();

};

}

注意:

1、query和exec都可以执行所有的sql语句,只是返回值不同而已。

2、query可以实现所有exec的功能。

3、当把select语句应用到 exec 时,总是返回 0

4、如果要看查询的具体结果,可以通过foreach语句完成循环输出

第三种种方法:预处理语句:prepare()语句和execute()语句

还可以通过bindParam()方法来绑定参数给execute()方法

$result['id']." ".$result['username']." ".$result['password'].'
';

}

使用默认模式-PDO::ERRMODE_SILENT(PDO中捕获sql语句中的错误方法一)

$query = "insert into `user_12`(username,password) VALUES ('cyy02','123')"$code = errorCode();if(empty($code)){echo '插入成功';

}else{var_dump(errorInfo());

}

};

}

注意:

在上面的代码中,在定义 INSERT 添加语句的时候,故意使用了错误的数据表名字user_12(正确的数据表名称是:user),这里是为了测试写的!

导致错误输出结果如下:

39cde2f837fc2ce9b156b4812ce7fb31.png

使用警告模式-PDO::ERRMODE_WARNING(PDO中捕获sql语句中的错误方法二)

设置为警告模式

$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_WARNING);$query = "select * from user_12"$result['username'];

}

echo '程序能够继续执行哦~';

};

}

注意:

在上面的代码中,在定义 SELECT 查询语句的时候,我们故意使用了错误的数据表名字user_12(正确的数据表名称是:user),这里是为了测试写的!

在设置为警告模式以后,如果sql 语句出现错误将会给出一个提示信息,但是程序仍然能继续执行下去,上面实例得到的结果如下图:

4d59317267d3291d217b634007069413.png

使用异常模式-PDO::ERRMODE_EXCEPTION(PDO中捕获sql语句中的错误方法三)

设置为异常模式

ERRMODE_EXCEPTION);$query = "delete * from user_12 where id = :id"$id = 5$res->bindParam(':id',1)">$idexecute();

}catch(PDOException echo 'error:'.echo 'code:'.$e->getCode().'
'echo 'file:'.$e->getFile().'
'echo 'line:'.$e->getLine().'
'echo 'trace:'.$e->getTraceAsString().'
';

}

注意:

在上面的代码中,在定义 DELETE 删除语句的时候,我们故意使用了错误的数据表名字user_12(正确的数据表名称是:user),这里是为了测试写的!

在设置为异常模式后,执行错误的sql语句,输出结果如下:

a24b6115c0e6678027e8c813b40f8b81.png

PDO中错误处理的方法一-errorCode()方法

在PDO中有两个获取程序中错误信息的方法:errorCode()方法和errorInfo()方法!

$query = "DELETE FROM user_12"$pdo->errorCode().'
';

}

运行结果如下:

471b325dfcedd4cf33a88ea34929cead.png

PDO中错误处理的方法二-errorInfo()方法

};

}

输出的结果如下图所示:

b43f082a2b5133534107d5cdb8f0e781.png

PDO中的事务处理

(1) 开启事务——beginTransaction()方法。

beginTransaction()方法将关闭自动提交(autocommit)模式,直到事务提交或者回滚以后才恢复。

(2)提交事务——commit()方法

commit()方法完成事务的提交操作,成功返回true,否则返回false。

(3)事务回滚——rollBack()方法

rollBack()方法执行事务的回滚操作。

beginTransaction();$query = "insert into user(username,email) VALUES ('cyy03','333',1)">if(errorCode()){echo '数据添加成功'echo '数据添加失败';

}事务提交

commit();

}die(事务回滚

rollBack();

}

最后输出的结果如下:数据添加成功

总结

以上是编程之家为你收集整理的PHP PDO mysql抽象层全部内容,希望文章能够帮你解决PHP PDO mysql抽象层所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值