Alexander,
> > BEGIN;
> > DECLARE total CURSOR
> > FOR SELECT=20
> > SUBSTR(datetime,1,7)||'-01 00:00:00' as month,
> > client,
> > SUM(money)
> > FROM stat
> > WHERE SUBSTR(datetime,1,7)=3D'2003-10'
> > GROUP BY month,client;
> > DELETE FROM stat WHERE SUBSTR(datetime,1,7)=3D'2003-10';
> > INSERT INTO stat FETCH ALL FROM total;
> > COMMIT;
> >
> > but it does not work, chokes on FETCH ALL.
Well, there's two problems with your program:
1) INSERT INTO .... FETCH ALL is not currently implemented. You would need to
use a loop, and insert one row at a time by value.
2) You can't insert the rows you've just deleted from the base tables. In
your example, the TOTAL cursor would be empty. I think that what you really
want is a temp table.
--
-Josh BerkusAglio Database SolutionsSan Francisco