Pervasive SQL 2000i 数据库上次事务查询

问题描述

我有一个名为 Pervasive SQL 2000i 的旧数据库,该数据库来自 90 年代末和 2000 年代初。除了来自 Actian(称为 Zen)和来自 Goldstar Software(足以回答我的问题)之外,文档很少。这篇文章是关于如何查询每个不同时期的数据的问题。这个问题可能适用于所有数据库,因为这只是一个标准的 SQL 语句,但在我的生活中,我仍然很难如何在单个 SQL 语句上检索数据。

我有一个像这样的 Pervasive 表:

CREATE TABLE `NLBAL` (
    `acct` VARCHAR(32),`PerioEndDate` DATE,`Amt` DECIMAL,`YTDAmt` DECIMAL
);

(由 wtools 创建表格)

然后是部分数据:

Acct                PeriodEndDate    Amt               YTDAmt          
01212121221220      2017-11-30       -5000             40000 
01212121221220      2017-12-31       -5000             40000          
12010111111111      2020-09-31       -4000             12000           
12010111111111      2020-10-31       1000              80000    

   

如果我使用这个 SQL 语句:

SELECT Acct,PeriodEndDate,Amt,YTDAmt FROM NLBAL 
WHERE PeriodEndDate = (SELECT Max(PeriodEndDate) FROM NLBAL)

当然,结果仅基于“最大”日期,将忽略其他帐户的先前日期,它将显示具有等效 = 最大日期的所有记录并忽略那些没有的记录(预期结果):

Acct                PeriodEndDate    Amt               YTDAmt          
12010111111111      2020-10-31       1000              80000  

如我们所见,我的查询无法从帐户“01212121221220”中获取结果,该帐户具有 2017 年的最后记录交易,并且由于 2020-10-31 是表中的最新记录,因此数据库将使用该日期过滤结果。

我希望结果是:

Acct                PeriodEndDate    Amt               YTDAmt          
01212121221220      2017-12-31       -5000             40000                   
12010111111111      2020-10-31       1000              80000  

我只想查询所有帐户及其相应的最后一笔交易(1 rec),无论日期是什么,只要它是每个帐户的最后一笔交易。这意味着结果只需要为每个帐户只有一个记录,其中记录的交易是基于最大/最近日期的最后一个。

我该怎么做?

感谢您的建议。

解决方法

好吧,我最终这样做了:

SELECT Acct,Max(PeriodEndDate) as PeriodEndDate FROM NLBAL     
WHERE ACCT IN
('01212121221220','12010111111111')
GROUP BY Acct --(I actually have more than 600 records to query.)

将结果导出到带有 Acct,PeriodEndDate 列的新表“ACCTPRD”。

然后我使用这个查询:

SELECT DISTINCT Acct,PeriodEndDate,Amt,YTDAmt FROM NLBAL 
WHERE PeriodEndDate in (SELECT PeriodEndDate FROM ACCTPRD WHERE Acct=NLBAL.Acct)

然后我得到了我想要的结果。但是,我愿意接受比我这里的建议更优化的建议。

谢谢。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...