何时在查询中使用 dbo 限定表或视图名称?

Posted

技术标签:

【中文标题】何时在查询中使用 dbo 限定表或视图名称?【英文标题】:When to qualify table or view name with dbo in a query? 【发布时间】:2010-11-25 13:07:13 【问题描述】:

我在 SQL Server 中有一个视图,比如说 MY_VIEW。

当我执行命令SELECT * FROM MY_VIEW 时,它工作正常。但是,当我执行它时 SELECT * FROM dbo.MY_VIEW 我得到 *Invalid object name 'MyDB.dbo.MY_VIEW'*

我使用 sa 连接到 SQL 服务器。

这有什么问题?我们什么时候应该使用 dbo.MY_VIEW,什么时候不应该使用?

更新:视图上的架构名称是 dbo,当我创建视图时,我也连接到了 sa。

Update2 我发现问题是区分大小写的排序规则。问题不是因为 dbo。字首。这是因为数据库排序规则区分大小写,查询中的表名大小写错误。

【问题讨论】:

试试这个:SELECT TABLE_CATALOG, TABLE_SCHEMA FROM INFORMATION_SCHEMA.VIEWS WHERE TABLE_NAME = 'MY_VIEW' 【参考方案1】:

您是否使用与 dbo 不同的架构名称创建对象?如果您在创建视图时没有对其进行限定,它将取决于您的用户帐户的默认架构名称。在 SQL 2k5 和 2k8 中,我相信默认行为是为每个用户创建一个新模式,而不是将它们分配给“dbo”模式。

【讨论】:

架构名称是 dbo,在创建它时我使用 sa 进行了连接。【参考方案2】:

您在主数据库中。您在 master 数据库中创建了视图。您的实际查询是SELECT * FROM MyDB.dbo.MY_VIEW。请尝试在 MyDB 数据库中创建视图。

【讨论】:

【参考方案3】:

我发现问题在于区分大小写的排序规则。问题不是因为 dbo。字首。这是因为数据库排序规则区分大小写,查询中的表名大小写错误。

【讨论】:

以上是关于何时在查询中使用 dbo 限定表或视图名称?的主要内容,如果未能解决你的问题,请参考以下文章

ORA-00942: 表或视图不存在解决方法

ORA-00942: 表或视图不存在 - Oracle

错误 360:无法修改子查询中使用的表或视图

如何在不使用临时表或视图的情况下在多个列上使用 PIVOT [重复]

无法使用视图定义中具有表的完全限定名称的视图编译 SSDT 数据库项目

Oracle中视图和同义词的区别