"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 여러 MySQL 테이블에 동시에 데이터를 삽입하는 방법은 무엇입니까?

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

2024년 12월 21일에 게시됨
검색:192

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, ...)");

주의

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

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3