2006-11-01

PHP5中PDO的简单使用

来源: 本站收集整理 作者:佚名 评论 0 条
 
 $db = new PDO($dsn, 'root', '');
 $count = $db->exec("INSERT INTO foo SET name = 'heiyeluren',gender='男',time=NOW()");
 echo $count;
 $db = null;
?>

  不明白啥意思,俺们来慢慢讲讲。这行:

$dsn = "mysql:host=localhost;dbname=test";

  就是构造我们的DSN(数据源),看看里面的信息包括:数据库类型是mysql,主机地址是localhost,数据库名称是test,就这么几个信息。不同数据库的数据源构造方式是不一样的。

$db = new PDO($dsn, 'root', '');

  初始化一个PDO对象,构造函数的参数第一个就是我们的数据源,第二个是连接数据库服务器的用户,第三个参数是密码。我们不能保证连接成功,后面我们会讲到异常情况,这里我们姑且认为它是连接成功的。

$count = $db->exec("INSERT INTO foo SET name = 'heiyeluren',gender='男',time=NOW()");
echo $count;

  调用我们连接成功的PDO对象来执行一个查询,这个查询是一个插入一条记录的操作,使用PDO::exec() 方法会返回一个影响记录的结果,所以我们输出这个结果。最后还是需要结束对象资源:

$db = null;

  默认这个不是长连接,假如需要数据库长连接,需要最后加一个参数:array(PDO::ATTR_PERSISTENT => true) 变成这样:

$db = new PDO($dsn, 'root', '', array(PDO::ATTR_PERSISTENT => true));

  一次操作就这么简单,也许跟以前的没有太大区别,跟ADOdb倒是有几分相似。

  【继续了解】

  假如我们想提取数据的话,那么就应该使用数据获取功能。(下面用到的$db都是上面已经连接好的对象)

<?php
 foreach($db->query("SELECT * FROM foo")){
  print_r($row);
 }
?>

  我们也可以使用这种获取方式:

<?php
 $rs = $db->query("SELECT * FROM foo");
 while($row = $rs->fetch()){
  print_r($row);
 }
?>

  假如想一次把数据都获取到数组里可以这样:

<?php
$rs = $db->query("SELECT * FROM foo");
$result_arr = $rs->fetchAll();
print_r($result_arr);
?>

Array
([0] => Array(
 [id] => 1
 [0] => 1
 [name] => heiyeluren
 [1] => heiyeluren
 [gender] => 男
 [2] => 男
 [time] => 2006-10-28 23:14:23
 [3] => 2006-10-28 23:14:23
)
}

  我们看里面的记录,数字索引和关联索引都有,浪费资源,我们只需要关联索引的:

<?php
$db->setAttribute(PDO::ATTR_CASE, PDO::CASE_UPPER);
$rs = $db->query("SELECT * FROM foo");
$rs->setFetchMode(PDO::FETCH_ASSOC);
$result_arr = $rs->fetchAll();
print_r($result_arr);
?>

  看上面的代码,setAttribute() 方法是设置部分属性,主要属性有:PDO::ATTR_CASE、PDO::ATTR_ERRMODE等等,我们这里需要设置的是PDO::ATTR_CASE,就是我们使用关联索引获取数据集的时候,关联索引是大写还是小写,有几个选择:

  PDO::CASE_LOWER -- 强制列名是小写
  PDO::CASE_NATURAL -- 列名按照原始的方式
  PDO::CASE_UPPER -- 强制列名为大写

  我们使用setFetchMode方法来设置获取结果集的返回值的类型,同样类型还有:

  PDO::FETCH_ASSOC -- 关联数组形式
  PDO::FETCH_NUM -- 数字索引数组形式
  PDO::FETCH_BOTH -- 两者数组形式都有,这是缺省的
共4页: 上一页 [1] 2 [3] [4] 下一页

(本文仅表明作者个人观点,不代表本站及其管理员立场.) 推荐 收藏 投稿 打印 返回 关闭
上一篇:如何用PHP脚本和PEAR类创建ZIP档案文件  
下一篇:怎样在PHP 中运用 SimpleXML 处理任务
    评论加载中…
 推荐文章
     

网站首页  -  网站地图 -   站长论坛  -  网站投稿  -    -  网站管理
Copyright © 2008 芜湖站长站 All Rights Reserved 皖ICP备07500611号