PHP PDO操作使用MySql
2014-12-28 16:47
477 查看
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来设置需要结果集合的类型。
相关文章推荐
- PHP中使用PDO操作MySQL
- 使用PHP操作mysql和mysqli与PDO的区别
- PHP使用数据库永久连接方式操作MySQL的是与非
- 测试php是使用pdo方式连接mysql
- PHP数据库编程-使用mysql扩展库对数据库操作
- PHP程序中使用PDO对象实现对数据库的增删改查操作(PHP+smarty)
- 边记边学PHP-(十六)PHP使用MySQL扩展库操作数据库
- PHP程序中使用PDO对象实现对数据库的增删改查操作的示例代码
- PHP―使用MYSQL来 进入用户管理中心进行更多的操作
- 源码安装的php和mysql 在使用pdo时报错
- 在PHP中使用MySQL Mysqli操作数据库 ,以及类操作方法
- PHP 使用PDO操作数据库异常
- PHP使用数据库永久连接方式操作MySQL的是与非
- PHP使用PDO操作数据库笔记总结
- PHP操作MYSQL乱码问题,使用SET NAMES utf8校正
- LINUX下PHP使用PDO访问MYSQL的连接设置注意事项
- PHP数据库编程-使用mysql扩展库对数据库操作
- 在PHP中 使用mysqli扩展库对mysql 的操作
- 在PHP中使用MySQL Mysqli操作数据库 ,以及类操作方法
- PHP - PDO 之 mysql 基础操作