通过数据库抽象层PDO可以访问多个数据库

//数据库抽象层PDO
//造DSN:驱动名:dbname=数据库名;host=服务器地址
$dsn = "mysql:dbname=mydb;host=localhost";
//造PDO对象
$pdo = new PDO($dsn,"root","xiao8888");
//写SQL语句
$sql = "select * from Info";
//执行SQL语句 //我们不这样执行,我们用预处理
//$v =$pdo->query($sql);
//返回的对象比较特殊,可以用循环遍历 //预处理:先把SQL语句放到服务器上等待我们给他指令去执行
//准备一条SQL语句
$stm = $pdo->prepare($sql);
//执行准备好的SQL语句
if($stm->execute())
{
//1.逐行取数据
var_dump($stm->fetch());
//2.取所有数据
var_dump($stm->fetchAll()); //包含关联数组与索引数组
var_dump($stm->fetchAll(PDO::FETCH_ASSOC)); //返回关联数组
var_dump($stm->fetchAll(PDO::FETCH_NUM)); //返回索引数组
var_dump($stm->fetchAll(PDO::FETCH_OBJ)); //返回对象
//3.取某一列
var_dump($stm->fetchColumn(1));
//4.返回对象
var_dump($stm->fetchObject());
}
else
{
echo "执行失败!";
}

我们在预处理时可以设置参数,然后给参数绑定值,但这种方法太复杂,不推荐使用,了解即可。例如:

//造对象
$dsn = "mysql:dbname=mydb;host=localhost";
$pdo = new PDO($dsn,"root","xiao8888");
//写SQL语句,参数用?或者字符串代替
$sql= "insert into Nation vlaues(?,?)"; //问号绑定的是索引数组
$sql= "insert into Nation vlaues(:code,:name)";//字符串绑定的是关联数组 //预处理
$stm = $pdo->prepare($sql); //给参数绑定值 太复杂,不推荐
$stm->bindParam(1,$code);//索引数组
$stm->bindParam(2,$name); $stm->bindParam("code",$code,PDO::PARAM_STR);//关联数组
$stm->bindParam("name",$name,PDO::PARAM_STR);
$code = "p007";
$name = "回族"; //执行
if($stm->execute())
{
echo "添加成功!";
}
else
{
echo "添加失败!";
}

我们可以用数组自动绑定参数,例如:

//造对象
$dsn = "mysql:dbname=mydb;host=localhost";
$pdo = new PDO($dsn,"root","xiao8888");
//写SQL语句,参数用?或者字符串代替
$sql= "insert into Nation vlaues(?,?)"; //问号绑定的是索引数组
$sql= "insert into Nation vlaues(:code,:name)";//字符串绑定的是关联数组
//预处理
$stm = $pdo->prepare($sql);
//造数组
$attr = array("n006","藏族");
$attr = array("code"=>"n006","name"=>"藏族");
//执行
if($stm->execute($attr))
{
echo "添加成功!";
}
else
{
echo "添加失败!";
}

我们也可以将提交过来的值作为数组去执行SQL语句,这样在添加或修改数据的时候会非常方便。例如:

先做一个简单的添加页面:

<form action="Add.php" method="post">
<input type="text" name="code" />
<input type="text" name="name" />
<input type="submit" value="添加" />
</form>

再做一个处理页面:

<?php
//造对象
$dsn = "mysql:dbname=mydb;host=localhost";
$pdo = new PDO($dsn,"root","xiao8888");
//写SQL语句
$sql = "insert into Nation values(:code,:name)";
//预处理
$stm = $pdo->prepare($sql);
//执行
if($stm->execute($_POST))
{
echo "添加成功!";
}
else
{
echo "添加失败!";
}

我们可以将PDO做成方法封装在数据库类里面,使之更加完善。

<?php
class DB
{
public $host="localhost"; //服务器地址 默认值为localhost
public $uid="root"; //数据库用户名 默认值为root
public $pwd="123"; //数据库密码 默认值为123
/*数据库抽象层PDO,可以从其他驱动访问数据库
参数:
$sql: SQL语句
$type: SQL语句类型,默认为0,代表查询语句,1代表其他语句
$qdm: 驱动名,默认为mysql
$db: 数据库名,默认为mydb*/ public function QueryPDO($sql,$type=0,$qdm="mysql",$db="mydb")
{
//1.造DSN
$dsn="$qdm:dbname=$db;host=$this->host";
//2.造PDO对象
$pdo=new PDO($dsn,$this->uid,$this->pwd);
//3.预处理
//准备一条SQL语句
$stm =$pdo->prepare($sql);
//执行SQL语句
$stm->execute();
if($type==0)
{
return $stm->fetchAll();
}
else
{
return $stm->execute();
}
}
}

数据库抽象层PDO的更多相关文章

  1. PHP数据库抽象层--PDO(PHP Data Object) [一]

    1.简介:(PDO数据库访问抽象层,统一各种 数据库的访问接口 ) PHP 数据对象 (PDO) 扩展为PHP访问数据库定义了一个轻量级的一致接口.实现 PDO 接口的每个数据库驱动可以公开具体数据库 ...

  2. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 2

    18.2  PDO所支持的数据库 使用PHP可以处理各种数据库系统,包括MySQL.PostgreSQL.Oracle.MsSQL等.但访问不同的数据库系统时,其所使用的PHP扩展函数也是不同的.例如 ...

  3. PHP 数据库抽象层pdo

    PDO是PHP数据对象(PHP Data Object)的缩写. pdo就是一个"数据库访问抽象层",作用是统一各种数据库的访问接口,能够轻松地在不同数据库之间进行切换,使得数据库 ...

  4. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 5

    18.5  使用PDO对象 PDO扩展类库为PHP访问数据库定义了一个轻量级.一致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函数执行查询和获取数据,大大简化了数据 ...

  5. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 1

    现在,如果你已经能熟练地使用MySQL客户端软件来操作数据库中的数据,就可以开始学习如何使用PHP来显示和修改数据库中的数据了.PHP提供了标准的函数来操作数据库.在PHP 5以上的版本中可以使用My ...

  6. 【代码总结】数据库抽象层PDO

    一.概述 PDO就是一个"数据库访问抽象层",起作用是统一各种数据库的访问接口,能够轻松的在不同数据库之间进行切换. 二.PDO的安装 编辑php.ini文件 添加 extensi ...

  7. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 12

    18.9  管理表books实例 在Web项目中,几乎所有模块都要和数据表打交道,而对表的管理无非就是增.删.改.查等操作,所以熟练掌握对表进行管理的这些常见操作是十分有必的.本例为了能更好地展示PD ...

  8. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 9

    18.7  PDO的事务处理 事务是确保数据库一致的机制,是一个或一系列的查询,作为一个单元的一组有序的数据库操作.如果组中的所有SQL语句都操作成功,则认为事务成功,那么事务被提交,其修改将作用于所 ...

  9. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 8-1

    18.6.5  获取数据 PDO的数据获取方法与其他数据库扩展非常类似,只要成功执行SELECT查询,都会有结果集对象生成.不管使用PDO对象中的query()方法,还是使用prepare()和exe ...

随机推荐

  1. 【Excle】在重复数据中对日期排序并查询最新的一条记录

    现在存在以下数据: 需要查询出以下数据 姓名       日期 张三       2017-12-14 李四       2017-12-16 在E1中写入以下公式:=IF(D2=MAX(IF($C$ ...

  2. 编辑mac系统环境变量后保存,提示没有权限用到下面这个命令

    编辑的文件是vim /etc/paths :w !sudo tee % %代表当前编辑文件名 MAC:查看端口占用情况: lsof -i tcp: list open files lsof -i 用以 ...

  3. ios 缩放图片(平铺)

    //缩放图片(平铺) - (UIImage *)resizeImage:(NSString *)imgName { UIImage *bgImage =  [UIImage imageNamed:im ...

  4. Delphi Math里的基本函数,以及浮点数比较函数

    Delphi里的好东西太多,多到让人觉得烦.这种感觉就是当年打游戏<英雄无敌3>,改了钱以后,有钱了每天都要造建筑,明明是好事,可是让人觉得烦. 先记录下来,以后再回来加强对Math单元的 ...

  5. go学习资料

    go书单 1.代码规范 https://github.com/golang/go/wiki/CodeReviewComments 2.基础知识 先看: https://github.com/mikel ...

  6. linux安全组配置

    万网的是这样子配置的:

  7. px值转rem值的Sublime Text 3自己主动完毕插件

    一个CSS的px值转rem值的Sublime Text 3自己主动完毕插件. 插件效果例如以下: 安装 克隆项目   https://github.com/hyb628/cssrem.git 进入pa ...

  8. js中有特殊字符的编码格式

    在get和post方法中,如果传入的参数值有特殊字符,如:“&”,在get中的url需要拼接,可以使用encodeURICompontent来编码来转化 回调就是在上面传递实际参数,传递给aj ...

  9. YUV Player

    https://github.com/Yonsm/RawPlayer RawPlayer https://github.com/latelee/YUVPlayer YUVPlayer https:// ...

  10. MySQL:习题(单表多条件查询二)

    Sutdent表的定义 字段名 字段描述 数据类型 主键 外键 非空 唯一 自增 Id 学号 INT(10) 是 否 是 是 是 Name 姓名 VARCHAR(20) 否 否 是 否 否 Sex 性 ...