PDO专题(五)-PDO的预处理操作

[复制链接]
查看: 118|回复: 0

585

主题

1179

帖子

6291

积分

管理员

人亦已歌

Rank: 12Rank: 12Rank: 12

积分
6291

活跃会员热心会员推广达人宣传达人突出贡献优秀版主荣誉管理论坛元老

发表于 2022-10-26 15:16:06 | 显示全部楼层 |阅读模式
预处理好处是:编译一次多次执行,用来解决一条SQL语句多次执行的问题,提高了执行效率。
预处理语句:
  1. prepare 预处理名字 from 'sql语句'
复制代码
执行预处理
  1. execute 预处理名字 [using 变量]
复制代码


PDO中的预处理——位置占位符
  1. <?php
  2.     $dsn='mysql:dbname=data;charset=utf8';
  3.     $pdo=new PDO($dsn,'root','root');
  4.     //创建预处理对象
  5.     $stmt=$pdo->prepare("insert into bank values (?,?)");   //?是占位符
  6.     //执行预处理
  7.     $cards=[
  8.         ['1003',500],
  9.         ['1004',100]
  10.     ];
  11.     foreach($cards as $card){
  12.         //绑定参数,并执行预处理,
  13.         //方法一:
  14.         /*
  15.         $stmt->bindParam(1, $card[0]);  //给SQL语句传参。占位符的位置从1开始
  16.         $stmt->bindParam(2, $card[1]);
  17.         $stmt->execute();               //执行预处理
  18.          */
  19.         //方法二:
  20.         /*
  21.         $stmt->bindValue(1, $card[0]);//给SQL语句传参。占位符的位置从1开始
  22.         $stmt->bindValue(2, $card[1]);
  23.         $stmt->execute();
  24.          */
  25.         //方法三:如果占位符的顺序和数组的顺序一致,可以直接传递数组
  26.         $stmt->execute($card);  
  27.     }
复制代码


PDO专题(五)-PDO的预处理操作 PDO专题(五)-PDO的预处理操作

PDO中的预处理——参数占位符
  1. <?php
  2. $dsn='mysql:dbname=data;charset=utf8';
  3. $pdo=new PDO($dsn,'root','root');
  4. //创建预处理对象
  5. $stmt=$pdo->prepare("insert into bank values (:p1,:p2)");   //:p1,:p2是参数占位符
  6. //执行预处理
  7. $cards=[
  8.     ['p1'=>'1005','p2'=>500],
  9.     ['p1'=>'1006','p2'=>1000]
  10. ];
  11. foreach($cards as $card){
  12.     //方法一:
  13.     /*
  14.     $stmt->bindParam(':p1', $card['p1']);
  15.     $stmt->bindParam(':p2', $card['p2']);
  16.     $stmt->execute();
  17.      */
  18.     //方法二:但数组的下标和参数名一致的时候就可以直接传递关联数组
  19.     $stmt->execute($card);
  20. }
  21. ?>
复制代码
PDO专题(五)-PDO的预处理操作 PDO专题(五)-PDO的预处理操作

总结
1、?是位置占位符
2、参数占位符以冒号开头
3、$stmt->bindParam()和$stmt->bindValue()区别
  1. bindParam的第二个参数只能是变量。bindValue的第二个参数可以是变量也可以是字面量。
复制代码
4、预处理的好处
  1. 提高执行效率
  2. 提高安全性
复制代码


懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1、请认真发帖,禁止回复纯表情,纯数字等无意义的内容!帖子内容不要太简单!
2、提倡文明上网,净化网络环境!抵制低俗不良违法有害信息。
3、如果你对主帖作者的帖子不屑一顾的话,请勿回帖。谢谢合作!
3、问答求助区发帖求助后,如有其他用户热心帮您解决问题后,请自觉点击设为最佳答案按钮。

精彩图文
 
 
在线客服
技术支持
工作时间:
8:00-18:00
软著登字:
1361266号
官方微信扫一扫

QQ|小黑屋|慈众营销 ( 粤ICP备15049986号 )|网站地图

自动发帖软件 | 自动发帖器 | 营销推广软件 | 网络营销工具 | 网络营销软件 | 网站推广工具 | 网络推广软件 | 网络推广工具 | 网页推广软件 | 信息发布软件 | 网站推广工具 | 网页推广软件

Powered by Discuz! X3.4   © 2012-2020 Comsenz Inc.  慈众科技 - Collect from 深圳吉宝泰佛文化有限公司 公司地址:罗湖区黄贝街道深南东路集浩大厦A1403

返回顶部 返回列表