]1 https://i.stack.imgur.com/mQimv.png
CREATE VIEW planView
SELECT
planID, planName, cost, quota, maxSpeed, shapedSpeed, typeID, typeName
FROM
Plans AS p
LEFT OUTER JOIN
accessType AS a ON p.typeID = a.typeID;
GO
这一直给我错误消息,我试图使两个 typeID 彼此相等,但仍然没有任何结果
您的表中有一个公共列。它对于 SQL Server 来说是不明确的,因为它不知道该列属于哪个表。
例如,如果您有cost
同时在plan
, and accessType
表,然后它会对应该返回什么感到困惑 -plan.cost
or accessType.cost
?
解决方案:
去你的select
line
SELECT planID, planName, cost, quota, maxSpeed, shapedSpeed, typeID, typeName
并使用指定表的名称.
操作员
我想问题来自于
typeID
在选择中,因为您已经使用了Left outer join
所以,的值typeID
两个表中的内容并不总是相同。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)