我正在尝试为新创建的数据库创建存储过程。然而,SSMS智能感知不能识别超过一半的已创建的表。

例如,在表的左边这一列,我有一个表dbo。当我在新的查询窗口中输入“dbo.”时,没有列出那个表,实际上37个表中只列出了17个。

我看不出智能感知和非智能感知列出的表格有什么不同。如果我手动输入dbo。房间,它是下划线,有一个错误

无效对象名称“dbo.Room”…

我是不是在摆桌子的时候漏掉了什么?

更新:我已经尝试刷新表列表(几次)


当前回答

解决了SSMS 2016。

有一个类似的问题,但智能感知不在编辑菜单。

似乎解决它的是打开和关闭智能感知,右键单击SQL编辑器,然后单击“智能感知启用”。再次右键单击“智能感知启用”,再次打开它。Ctr Q,我也这么做。

这解决了问题,我也知道在编辑菜单上获得智能感知。

其他回答

我在Azure SQL Server上工作。对于存储数据,我使用表值参数 就像

DECLARE @INTERMEDIATE_TABLE3 TABLE { 
     x int;
 }

我发现了写查询时的错误

SELECT
    *
FROM 
    [@INTERMEDIATE_TABLE3]
WHERE 
    [@INTERMEDIATE_TABLE3].[ConsentDefinitionId] = 3

在查询列时,可以使用[@INTERMEDIATE_TABLE3]这样的大括号将其括起来。[ConsentDefinitionId]但是当只引用表值的param时,不应该有params。所以它应该被用作@INTERMEDIATE_TABLE3

所以现在必须将代码更改为

SELECT
    *
FROM 
    @INTERMEDIATE_TABLE3
WHERE 
    [@INTERMEDIATE_TABLE3].[ConsentDefinitionId] = 3

在我的例子中,智能感知缓存为一个完全不同的数据库列出对象信息。如果我单击SSMS中的“New Query”按钮,它将打开一个对服务器上默认编目的查询,并且该查询编辑器将始终只使用该数据库。刷新缓存不会改变任何东西。重新启动SSMS并没有改变任何东西。改变数据库并没有改变任何东西。

我最终通过右键单击我实际想要使用的数据库并从上下文菜单中选择“New query”来创建一个查询。现在SSMS使用正确的对象进行智能感知。

确保选中的DB就是表所在的DB。我在Master上运行脚本。在我的例子中,我必须切换到hr_db。

新手的错误但是,可以帮助别人。

我意识到这个问题已经有了答案,但是,我有一个不同的解决方案:

如果您正在编写一个脚本,其中删除了表而没有重新创建它们,那么在稍后尝试引用这些表时,这些表将显示为丢失。

注意:对于经常运行的脚本,这不会发生,但有时使用带有查询的脚本比每次都输入查询要容易得多。

我只需要关闭SMSS并重新打开它。我尝试刷新本地缓存,但没有工作。