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