【问题标题】:Update Column from another column in same table从同一表中的另一列更新列
【发布时间】:2019-07-25 19:16:00
【问题描述】:

我们需要在表格中更新我们的邮件地址,因为我们有一个新的域部分。本地部分保持不变

表格中有姓名、姓氏和邮件列。 (以及其他不重要的列)。

我们希望它最终看起来像这样:

Name    Surname     Mail
Test    Name        Test.Name@newdomain.com
Test2   Name2       Test2.Name2@newdomain.com

但在尝试这样做时,我们破坏了它,现在邮件列只显示新域。我们使用了以下代码:

update table
set mail = Replace('olddomain.com','newdomain.com')
where mail LIKE '%olddomain.com'

所以现在我们需要恢复邮件列并添加新的域部分。有什么帮助吗?

【问题讨论】:

  • 标记您正在使用的 DBMS。

标签: mysql sql sql-server-2008


【解决方案1】:

replace() 接受三个参数

update table
set mail = Replace(mail,'@olddomain.com','@newdomain.com')
where mail LIKE '%olddomain.com'

【讨论】:

    【解决方案2】:

    我很惊讶这有效。通常,replace() 接受三个参数:

    set mail = Replace(mail, 'olddomain.com', 'newdomain.com')
    

    我可能会建议您在逻辑中也包含@

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-04-18
      • 2020-09-09
      • 2014-12-08
      • 2023-01-13
      • 1970-01-01
      • 1970-01-01
      • 2023-02-22
      • 1970-01-01
      相关资源
      最近更新 更多