【问题标题】:MySQL trying to update a table from values stored in a temp tableMySQL 尝试从存储在临时表中的值更新表
【发布时间】:2011-05-16 15:49:07
【问题描述】:

我正在从表中进行选择,以在我的永久表中填写要更新的值。 MySQL 抱怨“'字段列表'中的未知列'rtufu.FollowUpDays'”。我做错了什么?

UPDATE FollowUpTbl 
  SET 
    FollowUpDate = DATE_ADD(NOW(), INTERVAL (rtufu.FollowUpDays) DAY) 
  WHERE FollowUpID IN (SELECT FollowUpID FROM RowsToUpdateFollowUps rtufu);

RowsToUpdateFollowUps (Temporary)
+------------+--------------+
| FollowUpID | FollowUpDays |
+------------+--------------+
|      64417 |           90 |
|      45508 |           90 |
+------------+--------------+

FollowUpTbl
+--------------+------------+
| FollowUpDate | FollowUpID |
+--------------+------------+
| 0000-00-00   |          1 |
| 0000-00-00   |          2 |
+--------------+------------+

【问题讨论】:

  • 请向我们展示 FollowUpTbl 和 RowsToUpdateFollowUps 的表架构。是临时表,会话关闭后不会清除吗?

标签: mysql select temp-tables


【解决方案1】:

您的查询语法有点混乱。试试这个。

UPDATE FollowUpTbl 
  SET 
    FollowUpDate = (
      SELECT
          DATE_ADD(NOW(), INTERVAL (rtufu.FollowUpDays) DAY)
          FROM RowsToUpdateFollowUps rtufu
          WHERE rtufu.FollowUpID = FollowUpTbl.FollowUpID
    );

【讨论】:

  • ERROR 1242 (21000):子查询返回多于 1 行
  • 您可能需要在 rtufu.FollowUpDays 周围添加 MAX() 或 MIN(),具体取决于您要实现的目标。
【解决方案2】:

rtufu 在“内部”(也称为嵌套)选择中定义。它在“外部”更新中不可见。

【讨论】:

    【解决方案3】:

    试试这个:

    update FollowUpTbl as f
        inner join RowsToUpdateFollowUps as t using (FollowUpID)
    set f.FollowUpDate = DATE_ADD(NOW(), interval t.FollowUpDays DAY);

    【讨论】:

    • 你的帖子比我早了大约 20 秒。
    • @Ben Dauphinee:对不起,下次回答之前我会问你:)
    【解决方案4】:

    内连接可用于更新。

    UPDATE FollowUpTbl f 
    INNER JOIN RowsToUpdateFollowUps rtufu ON rtufu.FollowUpID = f.FollowUpID 
    SET f.FollowUpDate = DATE_ADD(
        NOW(), 
        INTERVAL (rtufu.FollowUpDays) DAY
    );
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-07-15
      • 1970-01-01
      • 2015-01-30
      • 2017-09-17
      相关资源
      最近更新 更多