1

我已经构建了下面的代码,用于从元数据中获取 SAS 注册表的列表。它工作正常,但由于大量的 WorkTables(PhysicalTable 的子类型)需要很长时间才能运行

data work.tables (keep=uri name);
  length uri name $256;
  n=1;
  do while(metadata_getnobj("omsobj:PhysicalTable?@Id contains '.'",n,uri)>=0);
    n+1;
    if substr(uri,8,9)='WorkTable' then continue;
    if metadata_getattr(uri, "SASTableName", name)=0 then output;
  end;
run;

有什么方法可以调整 uri,以便可以在元数据查询本身中排除 WorkTable 类型?

例如如下(不起作用):

omsobj:PhysicalTable?@Id contains '.' and @MetadataType ne 'WorkTable'
4

1 回答 1

1

所以下面的 URI 起到了作用,尽管它只快了 20%:

omsobj:PhysicalTable?@Id contains '.' and @PublicType = 'Table'

这当然可以缩短为:

omsobj:PhysicalTable?@PublicType = 'Table'

这减少了额外的 0.2 秒。

于 2016-11-07T13:28:49.243 回答