PHP PDO操作使用MySql

1.安装PDO:

打开 c:\windows\php.ini ,找到下面这行:

extension_dir

这个就是我们扩展存在的目录,我的PHP 5扩展是在:E:/AppServ\php5\ext,那么我就把这行改成:

extension_dir = "E:/AppServ\php5\ext" 

然后再往php.ini下面找到:

Dynamic Extensions ;

下面有一堆类似 ;extension=php_mbstring.dll 的东西,这里就是PHP扩展加载的配置了,我们在最后面添加上我们PDO的扩展:

extension=php_pdo.dll  
extension=php_pdo_mysql.dll  
extension=php_pdo_pgsql.dll  
extension=php_pdo_sqlite.dll  
extension=php_pdo_mssql.dll  
extension=php_pdo_odbc.dll  
extension=php_pdo_firebird.dll  
;extension=php_pdo_oci8.dll 

PHP PDO的驱动,能给加上的全给加上。不过后面的php_pdo_oci8.dll,我没有安装Oralce数据库,所以就使用分号注释掉它。然后重启我们的Apache服务器。

2.使用PDO:


连接数据库:

<?php
$dbms='mysql';     //数据库类型,使用不同的数据库,只需改这个
$host='localhost'; //数据库主机名
$db_name='test';    //使用的数据库
$user='root';      //数据库连接用户名
$pass='1';         //对应的密码
$dsn="$dbms:host=$host;dbname=$db_name";


try {
    $dbh = new PDO($dsn, $user, $pass); //初始化一个PDO对象,就是创建了数据库连接对象$dbh
    echo "连接成功<br/>";
    /*你还可以进行一次搜索操作
    foreach ($dbh->query('SELECT * from foo') as $row) {
        print_r($row); //你也可以用 echo($GLOBAL); 
    }
    */
    $dbh = null;
} catch (PDOException $e) {//记录错误,跳出
	file_put_contents('PDOErrors.txt', $e->getMessage(), FILE_APPEND);
    die ("Error!: " . $e->getMessage() . "<br/>");

}
//默认这个不是长连接,如果需要数据库长连接,需要最后加一个参数:array(PDO::ATTR_PERSISTENT => true) 变成这样:
$db = new PDO($dsn, $user, $pass, array(PDO::ATTR_PERSISTENT => true));

?>

查询数据:

foreach ($dbh->query('SELECT * from foo')->fetchAll(PDO::FETCH_ASSOC) as $row) {
        print_r($row);
    }
还可以这样:(查)
$rs = $dbh->query("SELECT * FROM foo");
	$rs->setFetchMode(PDO::FETCH_ASSOC);
	$result_arr = $rs->fetchAll();
	print_r($result_arr);


例子中的$rs->setFetchMode(PDO::FETCH_ASSOC);  是PDOStatement::setFetchMode(),对返回类型的声明。

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

PDO::FETCH_ASSOC -- 关联数组形式
PDO::FETCH_NUM   -- 数字索引数组形式
PDO::FETCH_BOTH  -- 两者数组形式都有,这是缺省的
PDO::FETCH_OBJ   -- 按照对象的形式,类似于以前的 mysql_fetch_object()


插入,更新,删除数据:

$dbh->exec("DELETE FROM foo WHERE id=1");

PDO常用方法:

PDO::query()主要是用于有记录结果返回的操作,特别是SELECT操作,
PDO::exec()主要是针对没有结果集合返回的操作,比如INSERT、UPDATE、DELETE等操作,它返回的结果是当前操作影响的列数。
PDO::prepare()主要是预处理操作,需要通过$rs->execute()来执行预处理里面的SQL语句
PDOStatement::fetchColumn() 是获取结果指定第一条记录的某个字段,缺省是第一个字段。
PDOStatement::fetch() 是用来获取一条记录,
PDOStatement::fetchAll()是获取所有记录集到一个中,获取结果可以通过PDOStatement::setFetchMode来设置需要结果集合的类型。


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值