[英]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.