>백엔드 개발 >PHP 튜토리얼 >PHP PDOStatement 객체 binpram(),bindvalue(),bindcolumn_php의 차이점 팁

PHP PDOStatement 객체 binpram(),bindvalue(),bindcolumn_php의 차이점 팁

WBOY
WBOY원래의
2016-05-16 20:30:561433검색

PDOStatement::bindParam — 매개변수를 지정된 변수 이름에 바인딩합니다.

PHP 변수를 전처리에 사용되는 SQL 문의 해당 명명된 자리 표시자 또는 물음표 자리 표시자에 바인딩합니다. PDOStatement::bindValue()와 달리 이 변수는 참조로 바인딩되며 PDOStatement::execute()가 호출될 때만 해당 값을 사용합니다.

PDOStatement::bindValue — 값을 매개변수에 바인딩합니다.

전처리에 사용되는 SQL 문의 해당 명명된 자리 표시자 또는 물음표 자리 표시자에 값을 바인딩합니다.

코드 복사 코드는 다음과 같습니다.

$stm = $pdo->prepare("user = :user인 사용자에서 * 선택");
$user = "잭";
//맞습니다
$stm->bindParam(":user",$user);
//오류
$stm->bindParam(":user","jack");
//맞습니다
$stm->bindValue(":user",$user);
//맞습니다
$stm->bindValue(":user","jack");

//bindParam을 사용할 때 두 번째 매개 변수는 변수 값이 아닌 변수 이름만 사용할 수 있고, BindValue는 특정 값만 사용할 수 있습니다.
?>

PDOStatement::bindColumn — 열을 PHP 변수에 바인딩합니다.

쿼리 결과 집합의 특정 열에 바인딩할 특정 변수를 조합합니다. PDOStatement::fetch() 또는 PDOStatement::fetchAll()을 호출할 때마다 열에 바인딩된 모든 변수가 업데이트됩니다.

코드 복사 코드는 다음과 같습니다.

함수 readData( $dbh ) {
$sql = '과일에서 이름, 색상, 칼로리를 선택하세요' ;
{
을 시도해 보세요 $stmt = $dbh -> 준비($sql);
$stmt -> 실행();

​​​​/* 열 번호로 바인딩 */
           $stmt -> bindColumn ( 1 , $name );
$stmt ->bindColumn(2, $colour);

~                                                   열 이름을 통한 바인딩 */
           $stmt -> bindColumn ( '칼로리' , $cals );

while ( $row = $stmt -> 가져오기 ( PDO :: FETCH_BOUND )) {
$data = $name . "t" . $cals ;
$data 인쇄 ;
       }
}
​​catch (PDOException $e) {
$ e 인쇄 -& gt;
}
}
readData( $dbh );
?>
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.