>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 동적으로 생성된 테이블 이름으로 SQL 쿼리를 실행하는 방법은 무엇입니까?

MySQL에서 동적으로 생성된 테이블 이름으로 SQL 쿼리를 실행하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-07 15:57:03914검색

How to Execute SQL Queries with Dynamically Generated Table Names in MySQL?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.