1、PDO对象的认识
PDO一是PHP数据对象(PHP Data Object)的缩写,为PHP访问数据库定义了一致接口,可以兼容现***上所有的主流数据库,不管使用哪种数据库,都可以用相同的函数(方法)来查询和获取数据。
2、启动PDO
编辑 php.ini 文件:
extension=php_pdo.dll
更改 php.ini 文件后需要重启 PHP 服务才能使新的配置指令生效。
3、 PDO连接数据库
$pdo=new PDO( "mysql:host=数据库服务;dbname=数据库名称","数据库用户名","连接密码")
例:
$dsn="mysql:host=127.0.0.1;dbname=php";
$dbuser="root";
$dbpwd="root";
$pdo=new PDO($dsn,$dbuser,$dbpwd);
4、 PDO关闭数据库
$pdo = null;
实例1.连接数据库
<?php try { $dsn = 'mysql:host=127.0.0.1;dbname=myphp'; $dbuser = 'root'; $dbpwd = 'root'; $pdo = new PDO($dsn, $dbuser, $dbpwd); } catch (PDOException $a) { die('数据库连接失败' . $a->getMessage()); } echo '数据库连接成功'; print_r($pdo);
运行实例 »
点击 "运行实例" 按钮查看在线实例
实例2.执行query(查询)返回预处理对象。
<?php try { $dsn = 'mysql:host=127.0.0.1;dbname=myphp'; $dbuser = 'root'; $dbpwd = 'root'; $pdo = new PDO($dsn, $dbuser, $dbpwd); } catch (PDOException $a) { die('数据库连接失败' . $a->getMessage()); } $sql = 'select * from staff'; //sql语句 ?> <table width="600" border="1"> <caption><h1>员工信息表</h1></caption> <thead> <?php foreach ($pdo->query($sql) as $aa): ?> <tr> <td><?php echo $aa['id']; ?></td> <td><?php echo $aa['name']; ?></td> <td><?php echo $aa['age']; ?></td> <td><?php echo $aa['sex'] ? '男' : '女'; ?></td> <td><?php echo $aa['mobile']; ?></td> </tr> <?php endforeach; ?>
运行实例 »
点击 "运行实例" 按钮查看在线实例
实例3.PDO增加一条数据
<?php try { $dsn = 'mysql:host=127.0.0.1;dbname=myphp'; $pdo = new PDO($dsn, 'root', 'root'); } catch (PDOException $a) { die('数据库连接失败' . $a->getMessage()); } $sql = "INSERT INTO `staff` (`name`, `age`, `sex`, `position`, `mobile`, `hiredate`) VALUES ('孙尚香', '19', '0', '刘备之妻', '13986521520', '1550910188');"; $res = $pdo->exec($sql); if ($res) { echo "操作已完成。"; }
运行实例 »
点击 "运行实例" 按钮查看在线实例
实例4.更新一条数据
<?php try { $dsn = 'mysql:host=127.0.0.1;dbname=myphp'; $pdo = new PDO($dsn, 'root', 'root'); } catch (PDOException $a) { die('数据库连接失败' . $a->getMessage()); } $sql = "UPDATE `staff` SET name='关云长' where id=2"; $res = $pdo->exec($sql); if ($res) { echo "操作已完成。"; }
运行实例 »
点击 "运行实例" 按钮查看在线实例