MySQL 插入多個表
嘗試使用單一 MySQL 查詢將資料插入多個表可能會產生意外結果。雖然看起來多個查詢可以解決問題,但將使用者表中的自動增量 ID 與設定檔表的手動使用者 ID 關聯起來卻是一個挑戰。
使用事務和LAST_INSERT_ID()
要在單一事務中插入多個表,請使用以下命令方法:
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 儲存在變數中
或者,將自增 ID 儲存在變數中,以便在後續查詢中引用它。這可以使用以下方法實現:
MySQL變數:
INSERT INTO ... SELECT LAST_INSERT_ID() INTO @mysql_variable_here; INSERT INTO table2 (@mysql_variable_here, ...);
PHP變數:
INSERT ... $result = mysql_query("SELECT LAST_INSERT_ID()"); $id = mysql_result($result, 0); INSERT INTO table2 ($id, ...);
事務注意事項
無論選擇哪一種方法,都要考慮中斷執行的潛在影響。如果沒有事務,資料庫中可能會出現不一致。為了防止這種情況,請將插入語句包裝在交易中,如上所示。
以上是如何在單一事務中有效率地將資料插入多個 MySQL 表中?的詳細內容。更多資訊請關注PHP中文網其他相關文章!