Thread: Greetings folks, dumb question maybe?

Greetings folks, dumb question maybe?

From
Josh
Date:
Hello, I'm a little new at this so please bear with me.

I am trying to create a function that loads 100M test records into a 
database,  however I am having a hard time building the function that 
does so.

I'm trying to do this in PGAdmin III for Ubuntu.  Is there something 
that I have wrong with this?  I know that this works in MySQL (and yes I 
know that MySQL bends the SQL Standards), but I am not sure what I am 
doing wrong exactly.  I am coming up with the error that says there's an 
error in my syntax near the v INTEGER := 0 line.  I get the same error 
in psql as I do in the PGAdmin III.

I have the following so far:

DECLARE
v INTEGER := 0;
BEGIN
while v < 100000000
DO
INSERT INTO unpart_tbl_test VALUES
(v, 'test string data', adddate('1995-01-01', (rand(v)*36520) mod 3652));
v := v + 1;
END WHILE;
END;

Any insight would be greatly appreciated.

- J


Re: Greetings folks, dumb question maybe?

From
Josh
Date:
On 05/12/2010 01:32 PM, Josh wrote:
> Hello, I'm a little new at this so please bear with me.
>
> I am trying to create a function that loads 100M test records into a 
> database,  however I am having a hard time building the function that 
> does so.
>
> I'm trying to do this in PGAdmin III for Ubuntu.  Is there something 
> that I have wrong with this?  I know that this works in MySQL (and yes 
> I know that MySQL bends the SQL Standards), but I am not sure what I 
> am doing wrong exactly.  I am coming up with the error that says 
> there's an error in my syntax near the v INTEGER := 0 line.  I get the 
> same error in psql as I do in the PGAdmin III.
>
> I have the following so far:
>
> DECLARE
> v INTEGER := 0;
> BEGIN
> while v < 100000000
> DO
> INSERT INTO unpart_tbl_test VALUES
> (v, 'test string data', adddate('1995-01-01', (rand(v)*36520) mod 3652));
> v := v + 1;
> END WHILE;
> END;
>
> Any insight would be greatly appreciated.
>
> - J

after some digging I had to first create a language plpgsql, then I 
changed the function to be as follows:

CREATE FUNCTION no_part_tbl() RETURNS void AS '
DECLARE
v INTEGER := 0;
BEGIN
WHILE v < 100000000 LOOP
INSERT INTO no_part_tbl VALUES
(v, "testing no parts", adddate("1995-01-01",
(rand(v)*36520 % 3652));
v := v + 1;
END LOOP;
END;
' LANGUAGE 'plpgsql';

And it seems to accepted the function finally.   SOrry for the waste of 
bandwidth and anyones time.  I'm not used to this syntax, so it will 
take me a bit to get on boad with it.

- J



Re: Greetings folks, dumb question maybe?

From
Richard Broersma
Date:
On Wed, May 12, 2010 at 10:32 AM, Josh <jgooding@ttitech.net> wrote:

> I am trying to create a function that loads 100M test records into a
> database,  however I am having a hard time building the function that does
> so.

Here is one idea a function, but is could be wrapped by one:

p2082849b=> INSERT INTO Testtable ( n, c, d )
p2082849b-> WITH RECURSIVE T(n,c,d) as ( SELECT 1, 'A', CAST(
'2009-12-31' AS DATE ) + INTERVAL '1 DAY'
p2082849b(>                    UNION ALL SELECT n + 1, c, d + INTERVAL '1 day'
p2082849b(>                                FROM T
p2082849b(>                               WHERE n <= 10000)
p2082849b-> SELECT n,c,d FROM T;
INSERT 0 10001


--
Regards,
Richard Broersma Jr.

Visit the Los Angeles PostgreSQL Users Group (LAPUG)
http://pugs.postgresql.org/lapug


Re: Greetings folks, dumb question maybe?

From
"Little, Douglas"
Date:
I've been using the generate_series function and finding it very useful. It generates an integer, but I cast to 'day'
interval.
Might be useful.
doug

-----Original Message-----
From: pgsql-sql-owner@postgresql.org [mailto:pgsql-sql-owner@postgresql.org] On Behalf Of Richard Broersma
Sent: Wednesday, May 12, 2010 4:05 PM
To: Josh
Cc: pgsql-sql@postgresql.org
Subject: Re: [SQL] Greetings folks, dumb question maybe?

On Wed, May 12, 2010 at 10:32 AM, Josh <jgooding@ttitech.net> wrote:

> I am trying to create a function that loads 100M test records into a
> database,  however I am having a hard time building the function that does
> so.

Here is one idea a function, but is could be wrapped by one:

p2082849b=> INSERT INTO Testtable ( n, c, d )
p2082849b-> WITH RECURSIVE T(n,c,d) as ( SELECT 1, 'A', CAST(
'2009-12-31' AS DATE ) + INTERVAL '1 DAY'
p2082849b(>                    UNION ALL SELECT n + 1, c, d + INTERVAL '1 day'
p2082849b(>                                FROM T
p2082849b(>                               WHERE n <= 10000)
p2082849b-> SELECT n,c,d FROM T;
INSERT 0 10001


--
Regards,
Richard Broersma Jr.

Visit the Los Angeles PostgreSQL Users Group (LAPUG)
http://pugs.postgresql.org/lapug

--
Sent via pgsql-sql mailing list (pgsql-sql@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-sql


Re: Greetings folks, dumb question maybe?

From
Jasen Betts
Date:
On 2010-05-12, Josh <jgooding@ttitech.net> wrote:
> Hello, I'm a little new at this so please bear with me.
>
> I am trying to create a function that loads 100M test records into a 
> database,  however I am having a hard time building the function that 
> does so.
>
> I'm trying to do this in PGAdmin III for Ubuntu.  Is there something 
> that I have wrong with this?  I know that this works in MySQL (and yes I 
> know that MySQL bends the SQL Standards), but I am not sure what I am 
> doing wrong exactly.  I am coming up with the error that says there's an 
> error in my syntax near the v INTEGER := 0 line.  I get the same error 
> in psql as I do in the PGAdmin III.
>
> I have the following so far:
>
> DECLARE
> v INTEGER := 0;
> BEGIN
> while v < 100000000
> DO
> INSERT INTO unpart_tbl_test VALUES
> (v, 'test string data', adddate('1995-01-01', (rand(v)*36520) mod 3652));
> v := v + 1;
> END WHILE;
> END;
>
> Any insight would be greatly appreciated.
>
> - J

don't need a function for that one.

INSERT INTO unpart_tbl_test SELECT  GENERATE_SERIES(0,9999999),    'teststring data',    date '1995-01-01'
+(floor(random()*36520)::int% 3652);
 


Re: Greetings folks, dumb question maybe?

From
Joshua Tolley
Date:
On Thu, May 13, 2010 at 10:09:51AM +0000, Jasen Betts wrote:
> On 2010-05-12, Josh <jgooding@ttitech.net> wrote:
> don't need a function for that one.
>
> INSERT INTO unpart_tbl_test
>  SELECT  GENERATE_SERIES(0,9999999),
>      'teststring data',
>      date '1995-01-01' +(floor(random()*36520)::int % 3652);

...and if you'd rather it were a function anyway, do this:

CREATE FUNCTION populate_table() RETURNS VOID AS $$   INSERT INTO unpart_tbl_test     SELECT
GENERATE_SERIES(0,9999999),       'teststring data',        date '1995-01-01' +(floor(random()*36520)::int % 3652); 
$$ LANGUAGE SQL;

--
Joshua Tolley / eggyknap
End Point Corporation
http://www.endpoint.com