首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL:从插入SELECT中获取返回结果

MySQL:从插入SELECT中获取返回结果
EN

Stack Overflow用户
提问于 2012-10-25 18:59:02
回答 3查看 3.3K关注 0票数 1

我有一个同时插入显式值和SELECTd内容的查询。我也在做基本的递增。

代码语言:javascript
运行
复制
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查询并返回任何结果?

EN

Stack Overflow用户

回答已采纳

发布于 2012-10-25 19:36:42

因为您的查询有一个结果,所以您可以将“LIMIT 1”存储在session/user-defined variable中。仍然有两个查询,但可重入;每个连接都是它自己的会话。

代码语言:javascript
运行
复制
<?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子句。

票数 2
EN
查看全部 3 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13067121

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档