| From: | Frank Bax <fbax(at)sympatico(dot)ca> | 
|---|---|
| To: | |
| Cc: | pgsql-novice(at)postgresql(dot)org | 
| Subject: | Re: count the number of rows in tables | 
| Date: | 2008-08-21 14:44:44 | 
| Message-ID: | 48AD7F5C.8090209@sympatico.ca | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-novice | 
A B wrote:
> I'd like to fill this table
> 
> foo (name varchar(100), rows integer);
> 
> with the number of rows for each table that my account has access to.
> But EXECUTE with SELECT ... INTO is not yet implemented.
> So how do I re-write this function?
> 
> create or replace function countrows() RETURNS void AS $$
> DECLARE
> 	rec RECORD;
> 	nr INTEGER;
> BEGIN
> 	FOR rec IN SELECT tablename FROM pg_tables WHERE tableowner='myaccount'
> 	LOOP
> 		EXECUTE 'SELECT count(*) INTO nr FROM '||rec.tablename;
> 		EXECUTE 'INSERT INTO foo (name,rows) VALUES ('||rec.tablename||','||nr||')';
> 	END LOOP;
> END;	
> $$ LANGUAGE plpgsql;
> 
insert into foo (name,rows) (select 'employee',count(*) from employee);
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Decibel! | 2008-08-22 05:38:34 | Re: Triggers and Function. | 
| Previous Message | A B | 2008-08-21 13:42:59 | count the number of rows in tables |