首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >处理SQL游标

处理SQL游标
EN

Stack Overflow用户
提问于 2011-10-26 06:56:13
回答 4查看 303关注 0票数 0

可能重复: SQL -从一个表中查找另一个表中不存在的记录

我有这张桌子

代码语言:javascript
复制
TableA  
uID   |   uData  
1     |   111  
2     |   222  
3     |   333  
4     |   444  
5     |   555  

Table B  
uID   |   uData2  
1     |   222  
2     |   444

我只想从TableA获取数据,而不是从TableB获取数据

输出

代码语言:javascript
复制
uID   |   uData  
1     |   111  
3     |   333 
5     |   555  

到目前为止,我做了这个解决方案

代码语言:javascript
复制
DECLARE allData CURSOR FOR
SELECT uData
FROM         TableA;
OPEN allData;
FETCH NEXT FROM allData;

print @allData;

--WHILE @@allData = '222'
--  BEGIN
--      FETCH NEXT FROM allData;
--  END
CLOSE allData;
DEALLOCATE allData;
GO

得到了这个错误

必须声明标量变量"@allData“。

在sql或任何其他解决方案中不使用while,还有其他方法吗?:)

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2011-10-26 07:04:40

尝尝这个

代码语言:javascript
复制
    SELECT *
    FROM TableA 
    WHERE uData NOT IN (
       SELECT uData2
       FROM TableB
    )
票数 3
EN

Stack Overflow用户

发布于 2011-10-26 07:04:18

只需使用左联接并筛选出第二个表中有数据的记录:

代码语言:javascript
复制
select t1.uID, t1.uData
from TableA t1
left join TableB t2 on t2.uData2 = t1.uData
where t2.uData2 is null
票数 2
EN

Stack Overflow用户

发布于 2011-10-26 07:02:42

不需要游标;只需使用以下方法从TableB中排除值:

代码语言:javascript
复制
select tableA.* 
from   tableA 
where  tableA.uData not in (select TableB.uData2 from TableB)

此外,您的CURSOR语法是错误的。查看这个快速的例子以获得适当的CURSOR语法,以供以后参考。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7899540

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档