PHP原生提供了PDO扩展,意思是PHP数据对象。php
DSN是指数据源名称,提供数据库连接的详细信息。通常包含如下信息:mysql
主机名或者IP地址git
端口号github
数据库名web
字符集sql
以上信息构成的DSN能够用于PDO类构造函数的第一个参数,第二个和第三个参数分别是数据库的用户名和密码。若是数据库须要认证,则须要提供这两个 参数。数据库
<?php try { $pdo = new PDO( 'mysql:host = 127.0.0.1;dbname=books;port=3306;charset=utf8', 'USERNAME', 'PASSWORD' ); } catch(PDOException $e) { echo "Database connection failed"; exit; }
把数据库凭证保存在一个位于文档根目录以外的配置文件中,而后在须要的文件中导入这个文件。数组
在SQL中使用用户的输入时,必定要过滤。所以须要使用PDO扩展的预处理语句和参数绑定,这项操做很是简单。预处理语句是PDO对象的实例,不过咱们不多直接去实例化这个类,而是经过PDO实例的prepare方法得到预处理语句的对象。这个方法得第一个参数是一个sql语句字符串,返回值是一个PDOStatement实例:安全
<?php $sql = 'SELECT id FROM users WHERE email = :email'; $statement = $pdo->prepare($sql);
在这个SQL语句中,email这个值能够安全的绑定任何值。函数
<?php $sql = 'SELECT id FROM users WHERE email = :email'; $statement = $pdo->prepare($sql); $email = filter_input(INPUT_GET, 'email'); $statement->bindValue(':email', $email);
预处理语句会自动过滤$email的值。PDOStatement的第三个参数能够制定绑定值的类型,不填的话默认就是字符串类型。可选的常量类型以下
PDO::PARAM_BOOL
PDO::PARAM_NULL
PDO::PARAM_INT
PDO::PARAM_STR(默认值)
若是执行的是select方法,返回的数据咱们须要使用fetch()、fetchAll()、fetchColumn()和fetchObject()方法获取查询结果。
//把预处理语句得到的结果当成关联数组处理 $sql = 'SELECT id, email FROM users WHERE email = :email'; $statement = $pdo->prepare($sql); $email = filter_input(INPUT_GET, 'email'); $statement->bindValue(':email', $email); $statement->execute(); //迭代结果 while(($result = $statement->fetch(PDO::FETCH_ASSOC)) !== false) { echo $result['email']; }
fetch、fetchAll方法的参数可选
PDO::FETCH_ASSOC:返回一个关联数组
PDO::FETCH_NUM:返回一个键为数字的数组,数组的键是数据库列在查询结果中的索引
PDO::FETCH_BOTH:返回一个既有键为列名又有键为数字的数组。
PDO::FETCH_OBJ:让fetch()和fetchAll()返回一个对象,对象的属性是数据库的列名。
不推荐使用fetchAll(),除非你能够十分肯定可用内存放得下整个查询结果。若是只关心查询结果中的一列,可使用fetchColumn()方法,这个方法的做用和fetch()方法相似,返回查询结果中下一行的某一列,该方法只有一个参数用于制定所须要的索引。
// 构建并执行SQL查询 $sql = 'SELECT id, name FROM users WHERE email = :email'; $statement = $pdo->prepare($sql); $email = filter_input(INPUT_GET, 'email'); $statement->bindValue(':email', $email); $statement->execute(); while(($emal = $statament->fetchCoulmn(1)) !== false) { echo $email; }
由于在SQL语句中,email出如今了第二个字段的位置,因此这里使用索引1取出来。咱们还可使用fetchObj()方法来获取查询结果中的行,这个方法把行行当成对象,对象的属性是查询结果中的列。
// 构建并执行SQL查询 $sql = 'SELECT id, name FROM users WHERE email = :email'; $statement = $pdo->prepare($sql); $email = filter_input(INPUT_GET, 'email'); $statement->bindValue(':email', $email); $statement->execute(); while(($result = $statament->fetchObj()) !== false) { echo $result->email; }
事务是指把一系列数据库语句当成单个的逻辑执行单元执行,也就是说事务中的一系列SQL查询要么都成功,要么不执行。事务的原子性能保证数据的一致性、安全性和持久性。事务还有一个很好的反作用就是提高性能,由于事务是把多个查询排成队列,一次性所有执行。
PHP专题系列目录地址:https://github.com/xx19941215/webBlogPHP专题系列预计写二十篇左右,主要总结咱们平常PHP开发中容易忽略的基础知识和现代PHP开发中关于规范、部署、优化的一些实战性建议,同时还有对Javascript语言特色的深刻研究。