duanaoou4105 2014-03-12 20:49
浏览 57
已采纳

PDO - 迭代绑定变量

I am trying to create a function to iteratively bind variables. This is what I have so far:

function prepareQuery($db, $query, $args) {
    // Returns a prepared statement
    $stmt = $db->prepare($query);
    foreach ($args as $arg => $value) {
        $stmt->bindParam($arg, $value);
        }
    return $stmt;
    }

This is how I'm using it:

$stmt = prepareQuery($db, "SELECT * FROM `Licenses` WHERE `verCode`=:verCode", Array(":verCode" => $verCode));
$verCode = "some_string";
$stmt->execute();
while ($info = $stmt->fetch()) {
    print_r($info);
    }

Though it doesn't print anything. I know the database entry exists, and the same query works from PHPMyAdmin. So, I think it's just a problem in how my function tries to create the bindings. How can I fix this? Thanks!

  • 写回答

1条回答 默认 最新

  • ds3422222222 2014-03-12 20:56
    关注
    1. Do not create a function to iteratively bind variables. PDO can do it already

      function prepareQuery($db, $query, $args) {
          $stmt = $db->prepare($query);
          $stmt->execute($args);
          return $stmt;
      }
      
    2. If it doesn't print anything, then it didn't find anything. As simple as that.

    3. You don't even need this prepare query function actually. Just amend PDO very little like this

      class myPDOStatement extends PDOStatement
      {
          function execute($data = array())
          {
              parent::execute($data);
              return $this;
          }
      }
      
      $user = 'root';
      $pass = '';
      $dsn  = 'mysql:charset=utf8;dbname=test;host=localhost';
      $opt  = array(
          PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
          PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
          PDO::ATTR_EMULATE_PREPARES   => TRUE,
          PDO::ATTR_STATEMENT_CLASS    => array('myPDOStatement'),
      );
      $pdo = new PDO($dsn, $user, $pass, $opt);
      

    and you'll be able to write such a neat chain:

    $sql  = "SELECT * FROM `Licenses` WHERE `verCode`=:verCode";
    $code = "some_string";
    $data = $pdo->prepare($sql)->execute([$code])->fetchAll();
    foreach ($data as $info) {
        print_r($info);
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画