From: | Markus Bertheau <twanger(at)bluetwanger(dot)de> |
---|---|
To: | postgres sql list <pgsql-sql(at)postgresql(dot)org> |
Cc: | Horst Schwarz <schwarz(at)bab24(dot)de> |
Subject: | ERROR: ExecEvalExpr: unknown expression type 108 |
Date: | 2003-06-30 16:10:18 |
Message-ID: | 1056989417.2297.25.camel@fluor |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Hi,
datetest=# select version();
version
----------------------------------------------------------------------
PostgreSQL 7.3 on i686-pc-linux-gnu, compiled by GCC gcc (GCC) 3.2.2
(1 запись)
datetest=# \d daten
Таблица "public.daten"
Колонка | Тип |
Модификаторы
----------------+-----------------------------+-------------------------------------------------------
id | integer | not null default
nextval('public.daten_id_seq'::text)
menge | integer |
von | timestamp without time zone |
bis | timestamp without time zone |
Индексы: daten_pkey ключевое поле btree (id)
datetest=# select * from daten;
id | menge | von | bis
----+-------+---------------------+---------------------
1 | 2 | 2000-01-01 10:00:00 | 2000-01-01 12:00:00
2 | 3 | 2000-01-01 11:00:00 | 2000-01-01 14:00:00
3 | 1 | 2000-01-01 14:00:00 | 2000-01-01 15:00:00
4 | 9 | 2000-01-01 12:00:00 | 2000-01-01 16:00:00
5 | 4 | 2000-01-01 10:00:00 | 2000-01-01 11:00:00
(записей: 5)
datetest=# select * from (select (select count(1) from (select von from
daten union select bis as von from daten) as d1 where d1.von < d2.von)
as number, von from (select von from daten union select bis as von from
daten) d2) as bar join (select (select count(1)+1 from (select von from
daten union select bis as von from daten) as d1 where d1.von < d2.von)
as number, von from (select von from daten union select bis as von from
daten) d2) as foo using (number);
ERROR: ExecEvalExpr: unknown expression type 108
To explain what I'm actually trying to do, I'll at first visualize the
data:
10 11 12 13 14 15 16 17 t
--------------------------------------------------->
[-----2------]
[---------3--------]
[---1--]
[----------9-------------]
[---4--]
This displays use periods for microphones, with the number of
microphones for each period of time. So from 10 to 12, one guy needs 2
microphones, and from 11 to 14 another guy needs 3, and so on.
Now let's suppose a third guy asks, if we have enough microphones for
his event from 10 to 17. I know how many microphones there are at all.
So I want to know the maximum number of microphones that are used at a
point in time within that period 10-17. That number is 12 obviously.
It's easy to find out how many microphones are in use at a certain point
in time:
datetest=# select sum(menge) from daten where von < '2000-01-01 10:30'
and bis > '2000-01-01 10:30';
sum
-----
6
(1 запись)
So I could ask the maximum of sum for each point in time from 10 to 17.
This is a lot of points in time. So if two points in time don't differ
with respect to the number of microphones in use, I want to look at only
one of them. For that I query the points in time where something
changes:
datetest=# select von from daten union select bis as von from daten;
von
---------------------
2000-01-01 10:00:00
2000-01-01 11:00:00
2000-01-01 12:00:00
2000-01-01 14:00:00
2000-01-01 15:00:00
2000-01-01 16:00:00
(записей: 6)
Now I want the point in time in the middle between each two subsequent
points in time, i.e. 10:30, 11:30, 12:30, 14:30, 15:30. These would be
the points in time I have to query the sum of microphones in use, then I
have to take the maximum of these sums. To achieve that, I insert a
record counter, topdog from IRC kindly showed me how to do that:
datetest=# select (select count(1) from (select von from daten union
select bis as von from daten) as d1 where d1.von < d2.von) as number,
von from (select von from daten union select bis as von from daten) d2;
number | von
--------+---------------------
0 | 2000-01-01 10:00:00
1 | 2000-01-01 11:00:00
2 | 2000-01-01 12:00:00
3 | 2000-01-01 14:00:00
4 | 2000-01-01 15:00:00
5 | 2000-01-01 16:00:00
(записей: 6)
And another one:
datetest=# select (select count(1) + 1 from (select von from daten union
select bis as von from daten) as d1 where d1.von < d2.von) as number,
von from (select von from daten union select bis as von from daten) d2;
number | von
--------+---------------------
1 | 2000-01-01 10:00:00
2 | 2000-01-01 11:00:00
3 | 2000-01-01 12:00:00
4 | 2000-01-01 14:00:00
5 | 2000-01-01 15:00:00
6 | 2000-01-01 16:00:00
(записей: 6)
Now I want to join these using number and then calculate the average of
both von columns:
datetest=# select * from (select (select count(1) from (select von from
daten union select bis as von from daten) as d1 where d1.von < d2.von)
as number, von from (select von from daten union select bis as von from
daten) d2) as table1 join (select (select count(1) + 1 from (select von
from daten union select bis as von from daten) as d1 where d1.von <
d2.von) as number, von from (select von from daten union select bis as
von from daten) d2) as table2 using (number);
ERROR: ExecEvalExpr: unknown expression type 108
Is that a bug?
Thanks
--
Markus Bertheau
Cenes Data GmbH
Berlin, Germany
From | Date | Subject | |
---|---|---|---|
Next Message | Rod Taylor | 2003-06-30 16:41:38 | Re: ERROR: ExecEvalExpr: unknown expression type 108 |
Previous Message | Erik Erkelens | 2003-06-30 14:50:12 | CREATE SEQUENCE fails in plpgsql function |