繁体   English   中英

Teradata标识列和易失性/临时表问题的解决方法

[英]Workaround for Teradata identity columns and volatile/temp tables issue

我是Teradata的新手,无法理解为什么我不能在volatile表中选择一个Identity列。 当执行类似以下的操作时,出现以下错误。

create multiset volatile table Temp_Events as
  (
    select es.eventSettingId, -- this is an identity column 
           evt.lob
    from ForecastDevDW.cal_eventSettings es
    join ForecastDevDW.cal_eventTypes evt
     on evt.eventTypeId = es.eventTypeId
  )
with data
  primary index (eventSettingId)
  on commit preserve rows;

错误:CREATE TABLE AS当前不支持标识列。

有什么方法可以在Teradata中的易失性/临时表中选择标识列? 此错误有任何解决方法吗? 另外,有人知道您为什么不能在易失性表中选择标识列吗? (我已经习惯了SQL Server,这根本不是问题。)

确实,这是一个奇怪的限制,即使类型转换到VarChar也会失败,并显示相同的错误消息。

但是有一种解决方法,将“选择”放入派生表中:

create multiset volatile table Temp_Events as
  (
    select *
    from
     (
       select es.eventSettingId, -- this is an identity column 
              evt.lob
       from ForecastDevDW.cal_eventSettings es
       join ForecastDevDW.cal_eventTypes evt
         on evt.eventTypeId = es.eventTypeId
     ) as dt
  )
with data
  primary index (eventSettingId)
  on commit preserve rows;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM