PDO进行sql报表编制结果集介绍及操作(两)
<span style="font-size:18px;">一个:运行准备好的语句和绑定参数insert
try {
$pdo=new PDO("mysql:host=localhost;dbname=xsphpdb", "root", "123456");
}catch(PDOException $e){
echo $e->getMessage();
}
/* pdo中有两种占位符号
*
* ? 參数 --- 索引数组。 按索引顺序使用
* 名字參数 ----关联数组。 按名称使用,和顺序无关
*/
$stmt=$pdo->prepare("insert into shops(name, price, num, desn) values(?
, ?, ?, ?)"); //全部SQL都可运行
//准备好了一条语句。并入到server端,也已经编译过来了,就差为它分配数据过来
// $stmt=$pdo->prepare("insert into shops(name, price, num, desn) values(:name,:price, :num, :desn)");
//绑定名字參数 顺序能够不一致和名字相应就可以
/* $stmt->bindParam(":name", $name);
$stmt->bindParam(":num", $num);
$stmt->bindParam(":desn", $desn);
$stmt->bindParam(":price", $p);
*/
////绑定 问好?參数---得按顺序绑定
$stmt->bindParam(1, $name, PDO::PARAM_STR);//第3个參数是数据类型可不用写,会自己主动找类型
$stmt->bindParam(3, $num, PDO::PARAM_INT);
$stmt->bindParam(4, $desn, PDO::PARAM_STR);
$stmt->bindParam(2, $p, PDO::PARAM_STR);
$name="wwww1";
$num=101;
$desn="hello1";
$p=34.51;
if($stmt->execute()){
echo "运行成功";
echo "最后插入的ID:".$pdo->lastInsertId();
}else{
echo "运行失败!
";
}
//多次插入------------想运行多次。。
。
N次,传值就可以
$name="wwww1";
$num=101;
$desn="hello1";
$p=34.51;
if($stmt->execute()){
echo "运行成功";
echo "最后插入的ID:".$pdo->lastInsertId();
}else{
echo "运行失败!";
}
二:预处理语句UPDATE
try {
$pdo=new PDO("mysql:host=localhost;dbname=xsphpdb", "root", "123456");
}catch(PDOException $e){
echo $e->getMessage();
}
/* pdo中有两种占位符号
*
* ? 參数 --- 索引数组, 按索引顺序使用
* 名字參数 ----关联数组。 按名称使用。和顺序无关
*/
//准备好了一条语句,并入到server端,也已经编译过来了。就差为它分配数据过来
//$stmt=$pdo->prepare("insert into shops(name, price, num, desn) values(?, ?, ?, ?
)"); //全部SQL都可运行
//update和insert一样
$stmt=$pdo->prepare("update shop set name=:name,num=:num,price=:price,desn=:desn where id=:id"); //全部SQL都可运行
//绑定名字參数 顺序能够不一致和名字相应就可以
$stmt->bindParam(":name", $name);
$stmt->bindParam(":num", $num);
$stmt->bindParam(":desn", $desn);
$stmt->bindParam(":price", $p);//变量名字随便写
$stmt->bindParam(":id", $id);
$name="nnn";
$num=101;
$desn="hello1";
$p=34.51;
$id=108;
if($stmt->execute()){
echo "运行成功";
//echo "最后插入的ID:".$pdo->lastInsertId();
}else{
echo "运行失败!
";
}
//接着传值运行第二次-----N次,这就是PDO预处理,仅仅会编译一次SQL,其它想运行传值就能够
$name="mmm";
$num=101;
$desn="hello1";
$p=34.51;
$id=109;
if($stmt->execute()){
echo "运行成功";
}else{
echo "运行失败。";
}
三:预处理插入多条
try {
$pdo=new PDO("mysql:host=localhost;dbname=xsphpdb", "root", "123456");
}catch(PDOException $e){
echo $e->getMessage();
}
/* pdo中有两种占位符号
*
* ? 參数 --- 索引数组。 按索引顺序使用
* 名子參数 ----关联数组, 按名称使用,和顺序无关
*/
$stmt=$pdo->prepare("insert into shops(name, price, num, desn) values(?, ?
, ?, ?)"); //全部SQL都可运行--syi===
//准备好了一条语句,并入到server端。也已经编译过来了。就差为它分配数据过来
// $stmt=$pdo->prepare("insert into shops(name, price, num, desn) values(:name,:price, :num, :desn)");
//绑定參数
/* $stmt->bindParam(":name", $name);
$stmt->bindParam(":num", $num);
$stmt->bindParam(":desn", $desn);
$stmt->bindParam(":price", $p);
*/
//绑定參数
$stmt->bindParam(1, $name, PDO::PARAM_STR);
$stmt->bindParam(3, $num, PDO::PARAM_INT);
$stmt->bindParam(4, $desn, PDO::PARAM_STR);
$stmt->bindParam(2, $p, PDO::PARAM_STR);
$name="wwww1";
$num=101;
$desn="hello1";
$p=34.51;
if($stmt->execute()){
echo "运行成功";
echo "最后插入的ID:".$pdo->lastInsertId();
}else{
echo "运行失败!";
}
$name="ooo";
$num=101;
$desn="hello1";
$p=34.51;
if($stmt->execute()){
echo "运行成功";
echo "最后插入的ID:".$pdo->lastInsertId();
}else{
echo "运行失败!";
}
四:不绑定參数。直接execute中带值运行sql
try {
$pdo=new PDO("mysql:host=localhost;dbname=xsphpdb", "root", "123456");
}catch(PDOException $e){
echo $e->getMessage();
}
/* pdo中有两种占位符号
*
* ?
參数 --- 索引数组, 按索引顺序使用
* 名子參数 ----关联数组, 按名称使用。和顺序无关
*/
//准备好了一条语句,并入到server端,也已经编译过来了,就差为它分配数据过来
$stmt=$pdo->prepare("insert into shops(name, price, num, desn) values(:name,:price, :num, :desn)");
// $stmt->execute($_POST);
//传值是能够不按顺序--这是名字參数
$stmt->execute(array(":price"=>99, ":name"=>"kkk1", ":num"=>"451", ":desn"=>"aaaaaa1"));
$stmt->execute(array(":price"=>88, ":name"=>"kkk2", ":num"=>"452", ":desn"=>"aaaaaa2"));
$stmt->execute(array(":price"=>77, ":name"=>"kkk3", ":num"=>"453", ":desn"=>"aaaaaa3"));
五:获取结果集
try {
$pdo=new PDO("mysql:host=localhost;dbname=xsphpdb", "root", "123456");
}catch(PDOException $e){
echo $e->getMessage();
}
//获取结果 fetch()取一条--返回的是关联和索引数组一起返回
//获取结果 fetchAll(); 得到得是二维数组
$stmt=$pdo->prepare("select id, name, price, num, desn from shops where id > :id order by id");
$stmt->execute(array(":id"=>100)); //假设预SQL没有參数时,execute也不用带參数 直接问运行就能够
$stmt->setFetchMode(PDO::FETCH_ASSOC);//设置全部的获取模式,全部是关联数组,以下就不用改啦,也能够卸载fetch里面(PDO::FETCH_ASSOC),不写就是默认的类型关联和索引都返回
/*
while($row=$stmt->fetch()){//获取全部查出来的值 循环
print_r($row);
echo '<br>';
}
*/
/*
$row=$stmt->fetch(PDO::FETCH_ASSOC);获取关联数组
$row=$stmt->fetch(PDO::FETCH_NUM); 获取索引数组
$row=$stmt->fetch(PDO::FETCH_BOTH); 关联和索引都返回--默认就是这个
print_r($row);
*/
$data=$stmt->fetchAll(PDO::FETCH_ASSOC); //同上,也能够直接$stmt->setFetchMode(PDO::FETCH_ASSOC);这么设置
echo '<pre>';
print_r($data);
echo '</pre>';</span>
版权声明:本文博客原创文章,博客,未经同意,不得转载。
PDO进行sql报表编制结果集介绍及操作(两)的更多相关文章
- 使用PDO执行SQL语句exec()、query()
在PHP脚本中,通过PDO执行SQL查询与数据库进行交互,可以分为三种不同的策略,使用哪一种方法取决于你要做什么操作. 1.使用PDO::exec()方法 当执行INSERT.UPDATE和DELET ...
- 六、K3 WISE 开发插件《直接SQL报表开发新手指导 - BOM成本报表》
======================== 目录: 1.直接SQL报表 ======================== 1.直接SQL报表 以BOM成本报表为例,在销售模块部署,需要购买[金蝶 ...
- 跟着百度学PHP[14]-PDO的错误处理模式&PDO执行SQL
我们在使用PDO去执行sql语句的时候并不会报错.如下案例所示: <?php try { //$pdo = new pdo("mysql:host=主机;port=端口;dbname= ...
- SQL Server 2005 系统数据介绍:dm_exec_connections
原文:SQL Server 2005 系统数据介绍:dm_exec_connections 转载:http://msdn.microsoft.com/zh-cn/library/ms181509(SQ ...
- SQL Server 2014 各版本介绍
SQL Server 2014 各版本介绍 目前,SQL Server 2014 分为主要版本和专业版. 在选择版本的时候可以根据您具体的需要进行抉择,如果你需要一个免费的数据库管理系统,那么就选择 ...
- SQL Server 存储中间结果集
在SQL Server中执行查询时,有一些操作会产生中间结果集,例如:排序操作,Hash Join和Hash Aggregate操作产生的Hash Table,游标等,SQL Server查询优化器使 ...
- SQL报表(Report Builder)里面的几个常见问题(持续更新)
一 SQL报表常常会遇到在表格中的相除,如果分母为零,一般会显示错误号,我们可以这么处理:(加上是A/B) ,, B) 但是我们不能这么写: ,,A/B) //我们不能这么写,会产生BUG,至于什么B ...
- 【荐】PDO防 SQL注入攻击 原理分析 以及 使用PDO的注意事项
我们都知道,只要合理正确使用PDO,可以基本上防止SQL注入的产生,本文主要回答以下几个问题: 为什么要使用PDO而不是mysql_connect? 为何PDO能防注入? 使用PDO防注入的时候应该特 ...
- java.sql.SQLException: 对只转发结果集的无效操作: last
出错代码如下:static String u = "user";static String p = "psw";static String url = &quo ...
随机推荐
- 【ASP.NET Web API教程】4.2 路由与动作选择
原文:[ASP.NET Web API教程]4.2 路由与动作选择 注:本文是[ASP.NET Web API系列教程]的一部分,如果您是第一次看本系列教程,请先看前面的内容. 4.2 Routing ...
- c vs c++ in strcut and class
c vs c++ in strcut and class 总习惯用c的用法,现在学习C++,老爱拿来比较.声明我用的是g++4.2.1 SUSE Linux.看例子吧 #include <ios ...
- 苹果新的编程语言 Swift 语言进阶(五)--控制流
Swift 语言支持C语言全部的控制语句.包含for 和while循环语句,if和switch条件语句,以及break和continue控制语句等. Swift 语言除了支持以上语句,还添加了一个f ...
- Servlet API中文版
基本类和接口 一.javax.servlet.Servlet接口 servlet抽象集是javax.servlet.Servlet接口,它规定了必须由Servlet类实现由servlet引擎识别和管理 ...
- ios block循环引用问题
ios开发中,开了ARC模式,系统自动管理内存,如果程序中用到了block就要注意循环引用带来的内存泄露问题了 这几天遇到一个问题,正常页面dismiss的时候是要调用dealloc方法的,但是我的程 ...
- win7+vs2008+opencv
1.下载安装VS2008,然后直接下载opencv的windows的安装版, 2.把opencv解压出来,我的路径为:D:\Program\opencv 3.配置PATH:电脑--属性--高级系统设置 ...
- nohup sort -k1 -n -t$'\t' ./bigfile.16 -o./test/bigfile.16.ok &
nohup sort -k1 -n -t$'\t' ./bigfile.16 -o./test/bigfile.16.ok &
- 高逼格UI-ASD(Android Support Design)
绪 今年的Google IO给我们android开发着带来了三样非常屌非常屌的library: ASD(Android Support Design) APL(Android Percent Layo ...
- php 用递归实现的无限级别分类
<?php header("Content-type:text/html; charset=utf-8"); /** * * @category contry_cate ...
- Linux pipe功能
1. 功能说明 pipe(管道建设): 1) 头 #include<unistd.h> 2) 定义函数: int pipe(int filedes[2]); 3) 函数说明: pipe() ...