Hi All,

I am using Postgresql 9.1  where have a partitioned table as below:

> events_20150101
> events_20150102
> events_20150103
> ...
> events_overflow


When I am running the following query it gives me result:
*SQL 1: *

> select all relname, pg_total_relation_size(relname::text) as s,
> substr(relname,18)::date as dt from pg_stat_user_tables where schemaname =
> 'partitions' and relname not like '%overflow'


But when I run the following one, it gives me error:
*SQL 2: *

> select * as ts
> from
> (
> select relname, pg_total_relation_size(relname::text) as s,
> substr(relname,18)::date as dt from pg_stat_user_tables where schemaname =
> 'partitions' and relname not like '%overflow'  order by
> pg_total_relation_size(relname::text) desc
> ) as q
> where dt = '2015-01-01'::date;
> *ERROR:  invalid input syntax for type date: ""*

However, explain is showing plan:

>  Sort  (cost=202.03..202.04 rows=1 width=64)
>    Sort Key:
> (pg_total_relation_size(((pg_stat_all_tables.relname)::text)::regclass))
>    ->  Subquery Scan on pg_stat_all_tables  (cost=201.93..202.02 rows=1
> width=64)
>          ->  HashAggregate  (cost=201.93..201.99 rows=1 width=136)
>                ->  Nested Loop Left Join  (cost=0.00..201.92 rows=1
> width=136)
>                      ->  Nested Loop  (cost=0.00..194.23 rows=1 width=132)
>                            Join Filter: (c.relnamespace = n.oid)
>                            ->  Seq Scan on pg_namespace n
> (cost=0.00..1.39 rows=1 width=68)
>                                  Filter: ((nspname <> ALL
> ('{pg_catalog,information_schema}'::name[])) AND (nspname !~
> '^pg_toast'::text) AND (nspname = 'partitions'::name))
>                            ->  Seq Scan on pg_class c  (cost=0.00..192.77
> rows=6 width=72)
>                                  Filter: ((relkind = ANY
> ('{r,t}'::"char"[])) AND (relname !~~ '%overflow'::text) AND
> ((substr((relname)::text, 18))::date = '2015-01-01'::date))
>                      ->  Index Scan using pg_index_indrelid_index on
> pg_index i  (cost=0.00..7.66 rows=2 width=8)
>                            Index Cond: (c.oid = indrelid)



Again, if I create a table and run the query it runs:

*SQL 3:*

> create table dba.tbl_list as  select all relname,
> pg_total_relation_size(relname::text) as s, substr(relname,18)::date as dt
> from pg_stat_user_tables where schemaname = 'partitions' and relname not
> like '%overflow' ;
> SELECT 558



> \d+ dba.tbl_list
>                  Table "dba.tbl_list"
>  Column  |  Type  | Modifiers | Storage | Description
> ---------+--------+-----------+---------+-------------
>  relname | name   |           | plain   |
>  s       | bigint |           | plain   |
>  dt      | date   |           | plain   |
> Has OIDs: no


*SQL 4:*

> select * from dba.tbl_list  where dt = '2015-01-01';
>           relname          |     s      |     dt
> ---------------------------+------------+------------
>  events_20150101 | 1309966336 | 2015-01-01
> (1 row)


Why the 2nd query is showing error? Is it a bug? Or am I doing any silly?
Any advice, please.

Thanks & Regards.

Reply via email to