1

在节点表中,伪列名称$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}'

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

但是,在下表中的值函数:

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

导致错误消息:

消息 207,级别 16,状态 1,第 2 行无效的列名称“$node_id”。

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

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

4

1 回答 1

0

解决方法:您可以在表值函数中定义一个别名,$node_id并在您的选择中使用它而不是伪列:

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;

如果 fact在文本SSMS下方显示一条红色波浪线(可能是错误或警告) :[SitesByName]

没有为“SitesByName”的“1”列指定任何列

于 2017-08-08T10:06:14.810 回答