PDO

MySQLI是针对MySQL数据库扩展的,是专门访问MySQL数据库的

PDO是一个数据库访问的一个扩展类,通过一个类访问多个数据库,就是一个数据访问抽象层,把类结合在一块了

可以访问别的数据库,是数据访问的抽象层

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head> <body> <?php
//PDO
//1.访问不同的数据库
//2.自带事务功能.通过回滚操作可以把操作内容恢复
//3.防止SQL注入 //PDO怎么用
/*//1.造对象
$dsn = "mysql:dbname=mydb;host=localhost";"驱动名:数据库名称;服务器地址"
$pdo = new PDO($dsn,"root","123"); //2.写SQL语句
$sql = "update nation set name='兽族' where code='n013'"; //3.执行SQL语句
//$r = $pdo->query($sql);执行查询之后返回了另外一个对象,需要通过另外一个对象去找
$r = $pdo->exec($sql);执行的是增删改*/ //事务功能 要么全执行成功,要么全执行失败
//造对象
$dsn = "mysql:dbname=1016;host=localhost";
$pdo = new PDO($dsn,"root","数据库密码"); //设置异常模式,如果出现错误,抛一个异常出来
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);/*设置属性(名称,值) 注意不要加双引号*/ //写SQL语句
$sql1 = "insert into nation values('n007','朝鲜族')";
$sql2 = "insert into nation values('n008','彝族')"; //启动事务,执行两条SQL语句,最终提交给事务,然后事务判断有没有问题,要是有问题就抛出问题
try//试着执行
{
//启动事务
$pdo->beginTransaction(); $pdo->exec($sql1);
$pdo->exec($sql2); //提交事务
$pdo->commit();
}
catch/*抓住*/(PDOException $e)//PDO抛出的一个类型
{
//$e->getMessage();显示错误信息
//回滚
$pdo->rollBack();
} /*final//最终执行的内容,出不出错都执行,一般写关闭代码(PHP不常见)
{ }*/ ?> </body>
</html>

1107test.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head> <body>
<?php //造对象
$dsn = "mysql:dbname=1016;host=localhost";
$pdo = new PDO($dsn,"root","数据库密码"); //写SQL语句,预处理语句
$sql = "select * from nation"; //准备执行
$st = $pdo->prepare($sql); //执行
$st->execute(); //读数据 fetch 一行或fetch all 全部
var_dump($st->fetchAll(PDO::FETCH_ASSOC)); ?>
</body>
</html>

1107chaxun.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head> <body> <?php //造对象
$dsn = "mysql:dbname=1016;host=localhost";
$pdo = new PDO($dsn,"root","数据库密码"); //写SQL语句,预处理语句,使用name占位(名称占位) 前面要加冒号
$sql = "insert into nation values(:code,:name)"; //准备执行
$st = $pdo->prepare($sql); //绑定参数
/*$st->bindParam(":code",$code,PDO::PARAM_STR);
$st->bindParam(":name",$name,PDO::PARAM_STR); $code="n011";
$name="土家族";*/
//用关联数组
$attr = array("code"=>"n012","name"=>"布依族"); //执行
$st->execute($attr); //总结:name占位,用的关联数组;?占位,用的索引数组 ?>
</body>
</html>

1107namezhanwei.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head> <body>
<?php //造对象
$dsn = "mysql:dbname=1016;host=localhost";
$pdo = new PDO($dsn,"root","数据库密码"); //写SQL语句,预处理语句 用问号占位置
$sql = "insert into nation values(?,?)"; //准备SQL语句,返回statement对象 用变量接收返回的statement对象
$st = $pdo->prepare($sql); //绑定参数 bind绑 Param参数 用问号站位的从1开始索引
/* 简化前
$st->bindParam(1,$code);
$st->bindParam(2,$name);
//可以在后面赋值也可以在前面
$code="n022";
$name="矮人族";*/
// 简化后 array数组
$attr = array("n010","蒙古族"); //提交执行,不用给SQL语句了,已经传过去了
var_dump($st->execute($attr)); //execute 成功返回true 失败返回false
//预处理语句里面用?占位的,给数组的时候要给索引数组,顺序要对应起来 ?>
</body>
</html>

1107sqlzhuru.php

PDO(20161107)的更多相关文章

  1. 我了个大擦-PDO(二)

    hi 昨天又213了,虽然有室友3点多才睡觉的客观影响,但是昨晚不想学东西是本质原因.今天搞起.打算3.4天之内,学完PDO和AJAX这两个,还望大家没事儿来骂骂我,免的我又偷懒. 1.PDO 二.P ...

  2. 会话控制之session和cookie(20161107)

    注:除了登录页面,每个页面,包括处理页面也要加,为了提高安全性 session尽量不用,因为很占内存 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML ...

  3. PHP 常用函数总结(二)

    4.PHP处理数据库的常用函数. 汇总表 PHP 5 MySQLi 函数 函数 描述 mysqli_affected_rows() 返回前一个 Mysql 操作的受影响行数. mysqli_autoc ...

  4. PDO操作mysql数据库(一)

    PHP连接mysql数据库: <?php$server = "localhost";$user = "root";$pwd = "123456& ...

  5. 11.7 (下午)开课二个月零三天 (PDO)

    PDO访问方式操作数据库   mysqli是专门访问MySQL数据库的,不能访问其它数据库.PDO可以访问多种的数据库,它把操作类合并在一起,做成一个数据访问抽象层,这个抽象层就是PDO,根据类操作对 ...

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

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

  7. PHP中的PDO操作学习(三)预处理类及绑定数据

    要说 PDO 中最强大的功能,除了为不同的数据库提供了统一的接口之外,更重要的就是它的预处理能力,也就是 PDOStatement 所提供的功能.因为它的存在,才让我们可以安心地去使用而不用操心 SQ ...

  8. PHP中的PDO对象操作学习(一)初始化PDO及原始SQL语句操作

    PDO 已经是 PHP 中操作数据库事实上的标准.包括现在的框架和各种类库,都是以 PDO 作为数据库的连接方式.基本上只有我们自己在写简单的测试代码或者小的功能时会使用 mysqli 来操作数据库. ...

  9. 搭建LNAMP环境(四)- 源码安装PHP7

    上一篇:搭建LNAMP环境(三)- 源码安装Apache2.4 一.安装PHP7 1.yum安装编译php需要的包 yum -y install libxml2 libxml2-devel curl- ...

随机推荐

  1. border-radius是向元素添加圆角边框的方法

    border-radius:10px; /* 所有角都使用半径为10px的圆角 */ border-radius: 5px 4px 3px 2px; /* 四个半径值分别是左上角.右上角.右下角和左下 ...

  2. Android之com.nostra13.universalimageloader加载图片抛出OutOfMemroyError错误的多种解决办法

    com.nostra13.universalimageloader是用来加载图片非常好的框架,但是也有问题,一旦图片过多的话,很容易就会提示OutOfMemroyError错误,也就是内存溢出的问题, ...

  3. ASP.NET下使用xml反序列化、缓存实现个性化配置文件的实时生效

    因为一些配置属性比较多,存在多组属性,因此结合xml解析.缓存技术,实现配置文化的自动解析.存入缓存.缓存依赖实时更新配置内容. 配置文件反序列化存入缓存的核心方法: public Class.Set ...

  4. Jsoup后台解析html、jsp网页

    在一些网络爬虫或者从第三方网站抓取信息的程序都面临1个问题,如何从网页中把所需的信息提取出来,Jsoup是个比较好的选择,它能把网站内容解析成Document,再从document中取element就 ...

  5. 支付宝ios支付请求Java服务端签名报的一个错(ALI40247) 原创

    今天做app的支付宝支付,遇到些问题,以前做支付宝支付签名都是直接在客户端App进行,今天下了最新版本ios的支付宝支付demo,运行demo时底部有红色的显眼字体,告知用户签名必须在服务端进行... ...

  6. tbl.js div实现的表格控件,完全免费,不依赖jquery

    html上现在有比较好用的表格控件是datatable,但是编辑.按钮等部分是收费的,只有基础功能免费.而且尺寸发生变化时需要手工刷新等繁琐操作较多.所以我开发一个免费的供大家使用. 本项目已用于&q ...

  7. PHP静态成员变量

    静态成员:静态类中的成员加入static修饰符,即是静态成员.可以直接使用类名+静态成员名访问此静态成员,因为静态成员存在于内存,非静态成员需要实例化才会分配内存,所以静态成员不能访问非静态的成员.. ...

  8. 在windows搭建react-native android 开发环境总结

    1.安装必须的软件 1.Python 2    注意勾选 Add python.exe to Path,选项,这样就可以在安装完成后,不用手动去添加环境变量    安装完,打开cmd.exe,输入py ...

  9. Ext Js详解指南

    什么是Ext JS 走进Ext的世界 Ext JS是一款富客户端开发框架它基于javascript.HTML和CSS开发而成,无需安装任何插件即可在常用浏览器中创建出绚丽的页面效果. 个人总结Ext ...

  10. [Hadoop] - 异常Cannot obtain block length for LocatedBlock

    在Flume NG+hadoop的开发中,运行mapreduce的时候出现异常Error: java.io.IOException: Cannot obtain block length for Lo ...