微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQL Server 2012中LEFT OUTER JOIN的SQL语法

由于缺少对* =(LEFT OUTER JOIN)运算符的支持,我们遇到了sql Server 2012的问题.

任何人都可以告诉我sql Server 2012的正确语法是什么,以下sqlsql Server 2008上正常工作?

SELECT 
    t7410.name,t7408.type,t7410.length,t7410.status,t7410.prec,t7410.scale,t7409.type 
FROM 
    dbo.syscolumns t7410,dbo.systypes t7408,dbo.sysobjects t7409,dbo.sysusers t7411,master.dbo.syslogins t7412 
WHERE 
    t7410.id = t7409.id 
    AND t7411.uid = t7409.uid 
    AND t7409.name = 'GENERAL'
    AND t7409.type IN ('U','S','V') 
    AND t7410.usertype *= t7408.usertype 
    AND t7412.sid = t7411.sid 
    AND t7412.name = user_name() 
ORDER BY 
    t7410.colid ASC

解决方法

为什么不使用ANSI JOIN语法编写它:
SELECT t7410.name,t7409.type 
FROM dbo.syscolumns t7410
INNER JOIN dbo.sysobjects t7409
    ON t7410.id = t7409.id
INNER JOIN dbo.sysusers t7411
    ON t7411.uid = t7409.uid 
INNER JOIN master.dbo.syslogins t7412 
    ON t7412.sid = t7411.sid 
LEFT JOIN dbo.systypes t7408
    ON t7410.usertype = t7408.usertype 
WHERE t7409.name = 'GENERAL'
    AND t7409.type IN ('U','V') 
    AND t7412.name = user_name() 
ORDER BY t7410.colid ASC

原文地址:https://www.jb51.cc/mssql/77916.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐