| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1790 人关注过本帖
标题:sqlserver 使用 with as merge时遇到一个奇怪的问题
只看楼主 加入收藏
A1exander
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2019-6-22
收藏
 问题点数:0 回复次数:0 
sqlserver 使用 with as merge时遇到一个奇怪的问题
直接上代码:
WITH T1 AS (
    SELECT
        ID,
        (CASE WHEN ID = 1 THEN 'AAA' ELSE 'BBB' END) AS NAME
    FROM
        test1
)
MERGE INTO test2 USING T1 ON test2.id = T1.id
WHEN MATCHED THEN
UPDATE SET test2.class = T1.NAME

当with as 语句里 包含了 case when,运行时就会报错:[Err] 42000 - [SQL Server]MERGE 语句必须以分号(;)结尾。
不使用case when 就正常执行
这是什么原因??
我在 with as 里,还必须使用 case when,这要如何解决??
搜索更多相关主题的帖子: sqlserver with merge CASE THEN 
2019-06-22 11:34
快速回复:sqlserver 使用 with as merge时遇到一个奇怪的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.028435 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved