我有一个同时插入显式值和SELECTd内容的查询。我也在做基本的递增。
INSERT INTO `table` (`myID`, `myVal1`, `myVal2`) SELECT `myID` + 1, 'explValHere', 'otherValThere')
FROM `table` ORDER BY `myID` DESC LIMIT 0,1我这样做是因为表有多个id,并且在特定的列中递增。所以我不能,就像你首先说的,使用自动递增和insert_id。
当然,问题是insert不会返回select,但它能吗?有没有办法运行这个insert查询并返回任何结果?
发布于 2012-10-25 19:36:42
因为您的查询有一个结果,所以您可以将“LIMIT 1”存储在session/user-defined variable中。仍然有两个查询,但可重入;每个连接都是它自己的会话。
<?php
$pdo = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'localonly', 'localonly');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
setup($pdo);
$query = "
    INSERT INTO tbl1 (myID, myVal1, myVal2)
    SELECT @foo:=myID+1, 'val1', 'val2' FROM tbl2 WHERE x=0 LIMIT 1
";
$pdo->exec($query);
foreach( $pdo->query('SELECT @foo as foo') as $row ) {
    echo $row['foo'];
}
function setup($pdo) {
    $pdo->exec('CREATE TEMPORARY TABLE tbl1 (myID int, myVal1 varchar(16), myVal2 varchar(16))');
    $pdo->exec('CREATE TEMPORARY TABLE tbl2 (myID int, x int)');
    $pdo->exec('INSERT INTO tbl2 (myID, x) VALUES (1,1),(2,1),(3,0),(4,0),(5,1)');
}tbl2中具有x=0的“第一个”记录是(myID=3,x=0),并且脚本打印4。
除了这个和存储过程等,(据我所知)没有什么像SQLServer的OUTPUT或postgresql的MySQL的RETURNING子句。
发布于 2012-10-25 19:04:15
您可以(在事务中)先读取值,然后再执行insert语句。
发布于 2012-10-25 19:09:34
在正常插入后尝试这样做
INSERT INTO `table` (`myID`, `myVal1`, `myVal2`) values ('xxx','xxxx','xxxx');然后使用以下命令执行queryget last inser id
$id=mysql_insert_id();然后更新插入的行,如下所示
mysql_query("update table set myid=$id where id=$id");https://stackoverflow.com/questions/13067121
复制相似问题