MySQL 쿼리에서 동적 테이블 이름 사용
MySQL에서 동적으로 생성된 테이블 이름으로 SQL 쿼리를 실행하면 오류가 발생할 수 있습니다. 이를 극복하기 위해 이러한 시나리오를 안전하고 효율적으로 처리하는 방법을 제공하는 준비된 문을 활용할 수 있습니다.
제공된 코드에서:
SET @id := '47'; SET @table := @id+'_2013_2014_voucher'; SELECT * FROM @table; Delete FROM @table where>
MySQL이 그렇지 않기 때문에 오류가 발생합니다. 쿼리에서 직접 "@table"을 유효한 테이블 이름으로 인식합니다.
이 문제를 해결하려면 준비된 문을 사용하여 테이블 이름을 기반으로 쿼리를 동적으로 구성할 수 있습니다. 다음 코드는 이를 달성하는 방법을 보여줍니다.
SET @id := '47'; SET @table := concat(@id,'_2013_2014_voucher'); set @qry1:= concat('select * from ',@table); prepare stmt from @qry1 ; execute stmt ;
MySQL에서는 "concat" 함수가 문자열 연결에 사용됩니다. 이를 사용하여 준비된 문 "@qry1" 내에서 테이블 이름을 구성합니다.
준비된 문이 생성되면 "execute stmt" 명령을 사용하여 실행할 수 있습니다. 이 접근 방식을 사용하면 구문 오류 없이 테이블 이름을 동적으로 생성하고 쿼리를 실행할 수 있습니다.
위 내용은 MySQL에서 동적으로 생성된 테이블 이름으로 SQL 쿼리를 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!