消息207内联表值函数中伪列的列名$ node_id无效

时间:2017-08-08 09:52:43

标签: graph-databases sql-server-2017 sql-server-2017-graph

在节点表中,伪列名$node_id引用节点id列的内部名称,建议使用伪列(参见SQL Graph Architecture §Node Table)。

例如,在创建下表后:

create table [Sites](
[SiteName] NVarChar(max) NOT NULL,
[EndPoint] NVarChar(max),
[SiteNameHash] as CheckSum([SiteName]) PERSISTED NOT NULL,
[EndPointHash] as CheckSum([EndPoint]) PERSISTED NOT NULL,

INDEX IX_Sites_NodeId UNIQUE CLUSTERED ($node_id),
INDEX IX_Sites_SiteName UNIQUE NONCLUSTERED (SiteNameHash, $node_id),
INDEX IX_Sites_EndPoint UNIQUE NONCLUSTERED (EndPointHash, $node_id))

as Node;

查询:

SELECT $node_id
  ,[SiteName]
  ,[EndPoint]
  ,[SiteNameHash]
  ,[EndPointHash]
FROM [EmersonAnalysis].[dbo].[Sites]
where $node_id =  '{"type":"node","schema":"dbo","table":"Sites","id":0}'

使用$node_id - 子句和SELECT - 子句中的伪列WHERE来选择单个节点(如果存在)。

但是,在下表值函数中:

create function SitesByName(
    @sitename as NVarChar(max))
RETURNS TABLE
WITH SCHEMABINDING
AS
    return select
        $node_id,
        [SiteName],
        [EndPoint],
        [SiteNameHash],
        [EndPointHash]
    from [dbo].[Sites]
    where [SiteNameHash] = CHECKSUM(@sitename) AND
        [SiteName] = @sitename;

类似的查询:

select
    fn.$node_id
from [Sites]
outer apply SitesByName([SiteName]) as fn

错误消息中的结果:

  

Msg 207,Level 16,State 1,Line 2   列名称'$ node_id'无效。

从函数中选择列时是否可以使用伪列名?如果是这样,我如何使用伪列名称?

PS。我正在使用 RC 2 v14.0.900.75。

1 个答案:

答案 0 :(得分:0)

Workarround:您可以在表值函数中为$node_id定义别名,并在select而不是伪列中使用它:

ALTER function [dbo].[SitesByName](
    @sitename as NVarChar(max))
RETURNS TABLE
WITH SCHEMABINDING
AS
    return select
        $node_id [NodeId],
        [SiteName],
        [EndPoint],
        [SiteNameHash],
        [EndPointHash]
    from [dbo].[Sites]
    where [SiteNameHash] = CHECKSUM(@sitename) AND
        [SiteName] = @sitename;

如果事实SSMS[SitesByName]下显示红色波浪线(可能是错误或警告),并带有以下文字:

  

没有为'SitesByName'

的列'1'指定列