1

通过在 Oracle 中通过 level < 10 从双重连接中选择级别,我可以生成整数子查询并将其转换为另一个序列。

这对 Sybase 可行吗?

PS我想查找表中没有数据的日期(缺失天数)。在 Oracle 中,我这样做:

select to_date('2012-01-01', 'yyyy-mm-dd')+level-1 from dual
    connect by level < to_date('2013-01-01', 'yyyy-mm-dd') - to_date('2012-01-01', 'yyyy-mm-dd')
  MINUS
select distinct date from TBL
    where date between to_date('2012-01-01', 'yyyy-mm-dd')
                   and to_date('2013-01-01', 'yyyy-mm-dd')

在 Sybase 中,用于MINUS的模拟是:

select whatever from table1 T1
  where not exists
  ( select 1 from table2 where id = T1.id )

但我不知道按级别连接的模拟...

更新有没有办法在 Sybase 中创建临时表而不实际将数据存储到磁盘?

4

2 回答 2

4

您使用的 Oracle 语法是用作行生成器的分层查询。Sybase 具有sa_rowgenerator系统过程,可用于在开始值和结束值之间生成一组整数。

下面将生成一列介于 1 和 255 之间的整数。

SELECT row_num FROM sa_rowgenerator( 1, 255 );
于 2013-05-18T13:23:05.253 回答
1

sa_rowgenerator 系统过程需要 DBA 权限。没有 DBA 权限的用户必须被授予 EXECUTE 权限才能运行存储过程。

于 2017-12-15T08:42:36.080 回答