
PDOStatement::bindParam 메소드는 SQL 쿼리에서 사용되는 변수의 값을 변경하지 않도록 하기 위해서는 PDOStatement::bindParam 메소드 대신 PDOStatement::bindValue 메소드를 사용하면 됩니다.
PDOStatement::bindValue 메소드는 변수의 값을 변경하더라도 SQL 쿼리에서 사용되는 변수의 값은 변경되지 않습니다.
예를 들어, 다음과 같이 코드를 작성할 수 있습니다.
#hostingforum.kr
php
$stmt = $pdo->prepare("SELECT * FROM 테이블명 WHERE 이름 = :name");
$stmt->bindValue(":name", "이름");
이러한 코드는 PDOStatement::bindParam 메소드 대신 PDOStatement::bindValue 메소드를 사용하였으며, 변수의 값을 변경하더라도 SQL 쿼리에서 사용되는 변수의 값은 변경되지 않습니다.
또한, PDOStatement::bindValue 메소드는 PDOStatement::bindParam 메소드보다 성능이 더 좋습니다.
하지만, PDOStatement::bindParam 메소드는 변수의 값이 변경되면 SQL 쿼리에서 사용되는 변수의 값도 함께 변경되므로, PDOStatement::bindParam 메소드는 변수의 값이 변경되지 않는 경우에만 사용할 수 있습니다.
따라서, PDOStatement::bindParam 메소드는 변수의 값이 변경되지 않는 경우에만 사용하고, 변수의 값이 변경되면 PDOStatement::bindValue 메소드를 사용하는 것이 좋습니다.
2025-04-30 17:50