溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP中PDOStatement::bindParam的作用是什么

發(fā)布時(shí)間:2021-06-12 18:19:47 來(lái)源:億速云 閱讀:127 作者:Leah 欄目:開發(fā)技術(shù)

今天就跟大家聊聊有關(guān)PHP中PDOStatement::bindParam的作用是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

PDOStatement::bindParam

PDOStatement::bindParam — 綁定一個(gè)參數(shù)到指定的變量名(PHP 5 >= 5.1.0, PECL pdo >= 0.1.0)

說(shuō)明

語(yǔ)法

bool PDOStatement::bindParam ( mixed $parameter , mixed &$variable [, int $data_type = PDO::PARAM_STR [, int $length [, mixed $driver_options ]]] )

綁定一個(gè)PHP變量到用作預(yù)處理的SQL語(yǔ)句中的對(duì)應(yīng)命名占位符或問(wèn)號(hào)占位符。 不同于PDOStatement::bindValue() ,此變量作為引用被綁定,并只在PDOStatement::execute()被調(diào)用的時(shí)候才取其值。

大多數(shù)參數(shù)是輸入?yún)?shù),即,參數(shù)以只讀的方式用來(lái)建立查詢。一些驅(qū)動(dòng)支持調(diào)用存儲(chǔ)過(guò)程并作為輸出參數(shù)返回?cái)?shù)據(jù),一些支持作為輸入/輸出參數(shù),既發(fā)送數(shù)據(jù)又接收更新后的數(shù)據(jù)。

參數(shù)

parameter

  • 參數(shù)標(biāo)識(shí)符。對(duì)于使用命名占位符的預(yù)處理語(yǔ)句,應(yīng)是類似 :name 形式的參數(shù)名。對(duì)于使用問(wèn)號(hào)占位符的預(yù)處理語(yǔ)句,應(yīng)是以1開始索引的參數(shù)位置。

variable

  • 綁定到 SQL 語(yǔ)句參數(shù)的 PHP 變量名。

data_type

  • 使用 PDO::PARAM_* 常量明確地指定參數(shù)的類型。要從一個(gè)存儲(chǔ)過(guò)程中返回一個(gè) INOUT 參數(shù),需要為 data_type 參數(shù)使用按位或操作符去設(shè)置 PDO::PARAM_INPUT_OUTPUT 位。

length

  • 預(yù)分配提示。

driverdata

  • 數(shù)據(jù)類型的長(zhǎng)度。為表明參數(shù)是一個(gè)存儲(chǔ)過(guò)程的 OUT 參數(shù),必須明確地設(shè)置此長(zhǎng)度。

driver_options

返回值

成功時(shí)返回 TRUE,或者在失敗時(shí)返回 FALSE。

實(shí)例

執(zhí)行一條使用命名占位符的預(yù)處理語(yǔ)句

<?php
/* 通過(guò)綁定的 PHP 變量執(zhí)行一條預(yù)處理語(yǔ)句 */
$calories = 150;
$colour = 'red';
$sth = $dbh->prepare('SELECT name, colour, calories
  FROM fruit
  WHERE calories < :calories AND colour = :colour');
$sth->bindParam(':calories', $calories, PDO::PARAM_INT);
$sth->bindParam(':colour', $colour, PDO::PARAM_STR, 12);
$sth->execute();
?>

執(zhí)行一條使用問(wèn)號(hào)占位符的預(yù)處理語(yǔ)句

<?php
/* 通過(guò)綁定的 PHP 變量執(zhí)行一條預(yù)處理語(yǔ)句 */
$calories = 150;
$colour = 'red';
$sth = $dbh->prepare('SELECT name, colour, calories
  FROM fruit
  WHERE calories < ? AND colour = ?');
$sth->bindParam(1, $calories, PDO::PARAM_INT);
$sth->bindParam(2, $colour, PDO::PARAM_STR, 12);
$sth->execute();
?>

使用 INOUT 參數(shù)調(diào)用一個(gè)存儲(chǔ)過(guò)程

<?php
/* 使用 INOUT 參數(shù)調(diào)用一個(gè)存儲(chǔ)過(guò)程 */
$colour = 'red';
$sth = $dbh->prepare('CALL puree_fruit(?)');
$sth->bindParam(1, $colour, PDO::PARAM_STR|PDO::PARAM_INPUT_OUTPUT, 12);
$sth->execute();
print("After pureeing fruit, the colour is: $colour");
?>

看完上述內(nèi)容,你們對(duì)PHP中PDOStatement::bindParam的作用是什么有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI