> 백엔드 개발 > PHP 튜토리얼 > SQL에서 준비된 문과 변수를 올바르게 연결하는 방법은 무엇입니까?

SQL에서 준비된 문과 변수를 올바르게 연결하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-16 02:50:11
원래의
462명이 탐색했습니다.

How to Properly Concatenate Variables with Prepared Statements in SQL?

Prepared 문과 변수 연결

Prepared 문을 사용할 때는 변수를 SQL 쿼리와 올바르게 연결하는 것이 중요합니다. 잘못된 구문은 다음 코드 조각에서 발생하는 것과 같은 오류로 이어질 수 있습니다.

$sql = 'SELECT * FROM `users` WHERE username LIKE \'%{$var}%' '; // Error: Number of variables doesn't match number of parameters
$sql = 'SELECT * FROM `users` WHERE username LIKE %{?}% '; // Error: Wrong SQL
로그인 후 복사

올바른 접근 방식

이러한 오류를 방지하려면 다음 단계를 따르세요.

  1. 매개변수를 준비된 외부의 와일드카드와 연결하세요. 명령문:
$likeVar = "%" . $yourParam . "%";
로그인 후 복사
  1. ?를 사용하여 쿼리를 준비합니다. 자리 표시자로:
$stmt = $mysqli->prepare("SELECT * FROM REGISTRY where name LIKE ?");
로그인 후 복사
  1. 매개변수를 준비된 명령문에 바인딩합니다:
$stmt->bind_param("s", $likeVar);
로그인 후 복사

이 예에서 $likeVar에는 다음과 같은 값이 포함됩니다. 와일드카드("%...%")로 검색합니다. 이를 s(문자열) 매개변수 유형에 바인딩하면 데이터베이스 쿼리에서 올바르게 처리됩니다.

대소문자 구분 안함

대소문자를 구분하지 않는 검색이 필요한 경우 COLLATE utf8mb4_bin 절을 쿼리:

$stmt = $mysqli->prepare("SELECT * FROM REGISTRY where name LIKE ? COLLATE utf8mb4_bin");
로그인 후 복사

위 내용은 SQL에서 준비된 문과 변수를 올바르게 연결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿