mysql PDO::prepare用法詳解

來源:互聯網
上載者:User
PDO::prepare — 準備要執行的SQL語句並返回一個 PDOStatement 對象(PHP 5 >= 5.1.0, PECL pdo >= 0.1.0)

說明

文法

public PDOStatement PDO::prepare ( string $statement [, array $driver_options = array() ] )

為 PDOStatement::execute() 方法準備要執行的SQL語句,SQL語句可以包含零個或多個命名(:name)或問號(?)參數標記,參數在SQL執行時會被替換。

你不能在 SQL 陳述式中同時包含命名(:name)或問號(?)參數標記,只能選擇其中一種風格。

預先處理 SQL 陳述式中的參數在使用PDOStatement::execute()方法時會傳遞真實的參數。

參數

statement:合法的SQL語句。

driver_options:此數組包含一個或多個 key=>value 對來設定 PDOStatement 對象的屬性, 最常使用到是將PDO::ATTR_CURSOR值設定為PDO::CURSOR_SCROLL來請求一個可滾動遊標。

傳回值

如果成功,PDO::prepare()返回PDOStatement對象,如果失敗返回 FALSE 或拋出異常 PDOException 。

執行個體

使用命名(:name)參數來準備SQL語句

<?php/* 通過數組值向預先處理語句傳遞值 */$sql = 'SELECT name, colour, calories    FROM fruit    WHERE calories < :calories AND colour = :colour';    $sth = $dbh->prepare($sql, array(PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY));    $sth->execute(array(':calories' => 150, ':colour' => 'red'));    $red = $sth->fetchAll();    $sth->execute(array(':calories' => 175, ':colour' => 'yellow'));    $yellow = $sth->fetchAll();    ?>

使用問號(?)參數來準備SQL語句

<?php/* 通過數組值向預先處理語句傳遞值 */$sth = $dbh->prepare('SELECT name, colour, calories    FROM fruit    WHERE calories < ? AND colour = ?');$sth->execute(array(150, 'red'));    $red = $sth->fetchAll();    $sth->execute(array(175, 'yellow'));    $yellow = $sth->fetchAll();    ?>

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.