加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL重复列名称错误

发布时间:2020-12-12 16:26:23 所属栏目:MsSql教程 来源:网络整理
导读:我试图在一个庞大的SQL语句中找到一个错误(不是我的) – 我已经削减了很多,以使其可读 – 即使削减它仍然会引发错误 SELECT DISTINCT Profiles.ID FROM (select * from Profiles RIGHT JOIN FriendList ON (FriendList.Profile = 15237) order by LastLoggedI
我试图在一个庞大的SQL语句中找到一个错误(不是我的) – 我已经削减了很多,以使其可读 – 即使削减它仍然会引发错误
SELECT DISTINCT Profiles.ID 
FROM 
   (select * from Profiles RIGHT JOIN FriendList ON (FriendList.Profile = 15237) 
    order by LastLoggedIn DESC ) as Profiles

这会返回错误

Duplicate column name ‘ID’

我已经测试了最后一部分(从Profiles中选择*按LastLoggedIn DESC排序)并且它本身可以正常工作

我试图通过更改DISTINCT部分中的列名而没有任何运气来进行故障排除.

我读到的一个解决方案是删除DISTINCT,但这没有帮助.

我只是看不到重复列错误的来源.这可能是数据库完整性问题吗?

任何帮助非常感谢.

解决方法

您的个人资料和FriendList表都有一个ID列.因为你说select *,你会在子选择中得到两个名为ID的列,这些列是Profiles的别名,而SQL不知道Profiles.ID引用哪一个(注意这里的Profiles指的是别名)子查询,而不是同名表).

由于您只需要ID列,因此可以将其更改为:

SELECT DISTINCT Profiles.ID FROM 
( select Profiles.ID from Profiles RIGHT JOIN FriendList ON (FriendList.Profile = 15237) 
order by LastLoggedIn DESC ) as Profiles

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读