【问题标题】:How to COALESCE two fields in the same one statement如何在同一个语句中合并两个字段
【发布时间】:2013-08-29 15:24:11
【问题描述】:

所以,我有 2 个字段,Other_EEsOther_EE_Names 来自同一个表。我想将两者合并到另一个表中的一个现有字段中而不会中断。两者都包含一些信息。到目前为止,我分别合并了这两个字段,但第二个字段覆盖了第一个字段。如何同时合并两个字段?这是我目前使用的。谢谢!

UPDATE MI
   SET MI.M_Reps_Contact_Info = M.Other_EE_Names + ' '+ M.Other_EEs +
                                COALESCE( MI.M_Reps_Contact_Info + 
                                          CHAR(13) + CHAR(10), '' )
  FROM dbo.suptbl_Sprint2_Interview AS M
 INNER JOIN dbo.suptbl_Sprint2_MgrInterview AS MI 
    ON M.Junction_ID = MI.Junction_ID`

【问题讨论】:

  • 你能展示样本数据和输出吗?我认为这没有任何问题,除非这两个 Other_EE 字段具有 NULL 值。
  • @Goat CO 结果输出是第二个字段的数据,这意味着最后推送的数据将被合并。这两个字段中都有一些数据。
  • 一些示例数据和所需的输出可能会有所帮助。

标签: sql sql-server-2005 coalesce


【解决方案1】:

如果第二个“覆盖”第一个,那么我猜测这些值可以为 NULL。

试试这个set 声明:

SET MI.M_Reps_Contact_Info = COALESCE(M.Other_EE_Names + ' ', '') +
                             COALESCE(M.Other_EEs, '') +
                             COALESCE(MI.M_Reps_Contact_Info + 
                                      CHAR(13) + CHAR(10), '' )

【讨论】:

  • 谢谢!它正在完成这项工作,但结果是重复的。现在我该如何阻止它继续重复数据?
  • 好的,从头开始重复数据!看起来是因为我多次运行 UPDATE 语句!所以这是我的解决方案:UPDATE MI SET MI.M_Reps_Contact_Info = COALESCE(M.Other_EE_Names + CHAR(13) + CHAR(10), '') + COALESCE(M.Other_EEs + CHAR(13) + CHAR(10), '') + COALESCE(MI.M_Reps_Contact_Info, '') FROM dbo.suptbl_Sprint2_Interview AS M INNER JOIN dbo.suptbl_Sprint2_MgrInterview AS MI ON M.Junction_ID = MI.Junction_ID P.S. "CHAR(13) + CHAR(10)" 因为换行
猜你喜欢
  • 2014-06-18
  • 2011-07-14
  • 1970-01-01
  • 2021-05-02
  • 2013-10-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多