我有以下查询:
SELECT script FROM d_stages WHERE id IN
(SELECT g.stage + :i FROM games g INNER JOIN sessions s ON
g.expired = 0 AND s.user = g.user AND s.token = :token)
- 内部 SELECT 通过给定令牌在“会话”表中查找用户 ID,然后查找该用户的未过期游戏。
- 它返回已修改的游戏阶段(递增、递减或不做任何修改,具体取决于 :i 值)。
- 外部 SELECT 从字典中返回找到的阶段的唯一脚本。
显然,修改后的阶段编号(g.stage + :i)应该写回数据库,因为游戏已经进化了。我可以更换SELECT script
with SELECT script, g.stage + :i
,并在另一个中使用修改后的数字(UPDATE
)查询,但也许我可以在单个查询中执行相同的操作?
我的数据库管理系统是 mySQL 5.5。
Regards,
您只能使用 UPDATE 查询进行更新。 UPDATE 查询只能返回一件事:受影响的行数。因此,您无法在单个查询中更新和选择所需的值。
因此,您必须使用额外的 UPDATE 查询来更新数据。您可以在 SELECT 查询之前或之后执行此操作,具体取决于代码中应提交新值的简单性或实际点。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)