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 ...
随机推荐
- 怎样学习java?
嗯.不知不觉中,学习java的时间快要两年了.在学习这两年中.遇到的挫折非常多,收货的知识也非常多.以下我给出我自己在学习过程中使用到的经验.以及相关的资源链接,希望每个爱编程.爱java的人.能够有 ...
- hadoop namanodejava
最近突然想看下hadoop源码,有利于处理一些突发问题.先从name启动开始, NameNode.java public static void main(String argv[]) throws ...
- UNIX下改动时间简单一例
UNIX下改动时间简单一例 仅仅输入date就显示当前的工作站时间,假设有root超级用户权限,加上參数能够改动 工作站的时间. 格式:date mmddHHMM[cc]yy mm--月份,dd--日 ...
- VB.NET<机房收费系统个人重构版>你都学会了什么(之五)
接着上篇我们说的配置文件,今天我们来说一下接口. 1.UML图 2.三层架构 3.Sqlhelper 4.配置文件 5.接口 6.设计模式 什么是接口呢?我们可以将接口理解为用于沟通的中介的抽象化.可 ...
- SWT可视化设计
SWT可视化设计,可以使用Google的WindowBuilder. 在Google Code中,搜索WindowBuilder就可以看到路径. 在Eclipse中 Help--->Inst ...
- Ubuntu 问题解决汇总
汇总一些ubuntu相关的问题 1.Ubuntu支持安装多媒体播放插件(新系统安装后必备) ubuntu-restricted-extras package allows users to insta ...
- Spring中继承配置的注入方法
(1)两个java类.一个父类一个字类 package com.lc.inherit; /* * 这里是父类 */ public class Student { protected String na ...
- WebService的相关使用
近期公司项目使用WebService ,这里简单做个总结. 事实上详细使用细节有些情况下须要改,还须要看实际情况,须要与server联调,详细沟通. 比方公司连接,非要把envelope.dotNet ...
- BZOJ 2809 APIO2012 dispatching Treap+启示式合并 / 可并堆
题目大意:给定一棵树,选定一棵子树中的一些点,薪水和不能超过m,求点的数量*子树根节点的领导能力的最大值 考虑对于每一个节点,我们维护一种数据结构,在当中贪心寻找薪金小的雇佣. 每一个节点暴力重建一定 ...
- 在 window7 window8下公布webService注意问题
李石磊 学习日记 错误形如: 解决方式: 1.将服务公布,在IIS下创建虚拟文件夹 2.为上面创建的虚拟文件夹创建单独的应用程序,方法是右击虚拟文件夹.点击"加入应用程序...", ...