>데이터 베이스 >MySQL 튜토리얼 >여러 MySQL 테이블에 동시에 데이터를 삽입하는 방법은 무엇입니까?

여러 MySQL 테이블에 동시에 데이터를 삽입하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-17 11:46:25549검색

How to Insert Data into Multiple MySQL Tables Simultaneously?

MySQL 여러 테이블에 삽입: 데이터베이스 정규화

MySQL에서는 여러 테이블에 동시에 데이터를 삽입하는 기능이 직접 지원되지 않습니다. 그러나 이 기능을 달성하기 위한 대체 접근 방식이 있습니다.

트랜잭션 사용

테이블 전체에서 데이터 일관성을 보장하려면 트랜잭션을 사용하는 것이 좋습니다. 트랜잭션은 일련의 쿼리를 단일 단위로 캡슐화하여 모든 쿼리가 함께 성공하거나 실패하도록 보장합니다.

다음은 트랜잭션을 사용하는 예입니다.

BEGIN;
INSERT INTO users (username, password) VALUES('test', 'test');
INSERT INTO profiles (userid, bio, homepage) VALUES(LAST_INSERT_ID(),'Hello world!', 'http://www.stackoverflow.com');
COMMIT;

자동 증가 검색 값

사용자 테이블의 자동 증가 ID를 프로필에 삽입하려면 테이블에서는 LAST_INSERT_ID() 함수를 사용할 수 있습니다. 그러나 후속 insert 문이 자체 자동 증가 열이 있는 테이블에 삽입되면 LAST_INSERT_ID() 값이 해당 테이블의 값으로 업데이트됩니다.

원래 LAST_INSERT_ID() 값을 보존하려면 거래 내 맞춤 변수에 저장하세요.

MySQL 사용 변수:

INSERT ...
SELECT LAST_INSERT_ID() INTO @mysql_variable_here;
INSERT INTO table2 (@mysql_variable_here, ...);

언어 변수 사용:

// PHP example
$mysqli->query("INSERT INTO table1 ...");
$userid = $mysqli->insert_id;
$mysqli->query("INSERT INTO table2 ($userid, ...)");

주의

다음 사항을 준수하는 것이 중요합니다. 여러 테이블에 삽입할 때는 데이터베이스 일관성을 고려하세요. 중단되면 트랜잭션은 모든 쿼리가 완전히 실행되거나 전혀 실행되지 않도록 합니다. 트랜잭션이 없으면 부분 삽입으로 인해 불일치가 발생할 수 있습니다.

위 내용은 여러 MySQL 테이블에 동시에 데이터를 삽입하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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