предполагая, что у меня есть две таблицы, names
и phones
и я хочу вставить данные из некоторого ввода в таблицы, в одном запросе - как это можно сделать?
Пожалуйста, если это можно сделать, объясните синтаксис.
предполагая, что у меня есть две таблицы, names
и phones
и я хочу вставить данные из некоторого ввода в таблицы, в одном запросе - как это можно сделать?
Пожалуйста, если это можно сделать, объясните синтаксис.
MySQL не поддерживает вставку нескольких таблиц в один оператор INSERT. Oracle - единственный, кого я знаю об этом, странно...
INSERT INTO NAMES VALUES(...)
INSERT INTO PHONES VALUES(...)
Вы не можете. Однако вы можете использовать транзакцию и иметь оба из них в одной транзакции.
START TRANSACTION;
INSERT INTO table1 VALUES ('1','2','3');
INSERT INTO table2 VALUES ('bob','smith');
COMMIT;
У меня была та же проблема. Я решаю его с помощью цикла for.
Пример:
Если я хочу писать в 2 идентичных таблицах, используя цикл
for x = 0 to 1
if x = 0 then TableToWrite = "Table1"
if x = 1 then TableToWrite = "Table2"
Sql = "INSERT INTO " & TableToWrite & " VALUES ('1','2','3')"
NEXT
либо
ArrTable = ("Table1", "Table2")
for xArrTable = 0 to Ubound(ArrTable)
Sql = "INSERT INTO " & ArrTable(xArrTable) & " VALUES ('1','2','3')"
NEXT
Если у вас небольшой запрос, я не знаю, является ли это наилучшим решением, но если ваш запрос очень большой и находится внутри динамического script с if/else/case условиями, это хорошее решение.
Несколько операторов SQL должны выполняться с помощью функции mysqli_multi_query()
.
Пример (MySQLi объектно-ориентированный):
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";
// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
$sql = "INSERT INTO names (firstname, lastname)
VALUES ('inpute value here', 'inpute value here');";
$sql .= "INSERT INTO phones (landphone, mobile)
VALUES ('inpute value here', 'inpute value here');";
if ($conn->multi_query($sql) === TRUE) {
echo "New records created successfully";
} else {
echo "Error: " . $sql . "<br>" . $conn->error;
}
$conn->close();
?>