我想在同一个表中插入2行。第一个将从select输入数据,第二个将使用vars作为数据。我可以插入第一行,但无法插入多行。
$ partner_id用于将行相互链接。为此我在php中使用生成的32char值。无论如何将edit_partner_id设置为mysql作为插入的第一行的id,或者这是不可能的,因为必须先创建第一行才能获得最后一个id?
是否可以为此添加更新,还是必须在单独的查询中运行此更新?
$sql = "INSERT INTO edits_customers (customer_id, creator_id, firstname, surname,
house_no, address_1, address_2, address_3, city, county, postcode,
country, email, home_tel, mobile_tel, work_tel, notes, edit_type,
edit_partner_id )
(SELECT *, 'before', '{$partner_id}' FROM customers WHERE customers.id = 123),
('{$var1}', '{$var2}', '', '', '', '', '', '', '', '', '', '', '', '', '', '',
'', 'after', $partner_id)";
由于
答案 0 :(得分:28)
如果我正确理解你的问题,你试图从另一个表中插入一些数据以及你自己提供的一些数据,你应该可以使用UNION做这样的事情:
INSERT INTO SomeTable ( Col1, Col2, Col3 )
SELECT Val1, Val2, Val3 FROM SomeOtherTable
UNION
SELECT 'MyProvidedVal1', 'MyProvidedVal2', 'MyProvidedVal3'
希望有帮助...