>  기사  >  데이터 베이스  >  MySQL에서 동적 테이블 이름을 사용하여 SQL 쿼리를 실행하는 방법은 무엇입니까?

MySQL에서 동적 테이블 이름을 사용하여 SQL 쿼리를 실행하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-09 10:56:02380검색

How to Execute SQL Queries with Dynamic Table Names in MySQL?

SQL 문의 동적 테이블 이름

동적 테이블 이름을 사용하여 SQL 쿼리를 실행하는 것은 어려울 수 있습니다. 다음 예를 고려하십시오.

SET @id := '47';
SET @table := @id+'_2013_2014_voucher';
SELECT * FROM @table;
Delete FROM @table where>

이 쿼리는 다음 오류를 발생시킵니다.

[Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '@table' at line 1

준비된 문을 사용한 솔루션

권장되는 접근 방식 동적 테이블 이름을 처리하는 것은 준비된 문을 사용하는 것입니다. 준비된 문을 사용하면 적절한 구문과 보안을 보장하면서 테이블 이름을 동적으로 지정할 수 있습니다. MySQL에서는 다음과 같이 PREPARE 및 EXECUTE 문을 사용할 수 있습니다.

SET @id := '47';
SET @table := concat(@id,'_2013_2014_voucher');
set @qry1:= concat('select * from ',@table);
prepare stmt from @qry1 ;
execute stmt ;

CONCAT() 함수는 테이블 이름 문자열을 동적으로 연결하는 데 사용됩니다. 그런 다음 구문 오류를 방지하면서 준비된 문이 실행됩니다.

쿼리 삭제에 적용

동일한 접근 방식을 쿼리 삭제에도 확장할 수 있습니다.

SET @qry2:= concat('DELETE FROM ',@table,' where>

위 내용은 MySQL에서 동적 테이블 이름을 사용하여 SQL 쿼리를 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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