| From: | Merlin Moncure <mmoncure(at)gmail(dot)com> |
|---|---|
| To: | Charles Gomes <charlesrg(at)outlook(dot)com> |
| Cc: | "pgsql-hackers(at)postgresql(dot)org" <pgsql-hackers(at)postgresql(dot)org> |
| Subject: | Re: Writing Trigger Functions in C |
| Date: | 2012-12-21 16:39:50 |
| Message-ID: | CAHyXU0zXgMeWbxeE4ra40jN7L7Z7-_4C_sG1L8eaO8t=xqt3DQ@mail.gmail.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-hackers |
On Fri, Dec 21, 2012 at 10:25 AM, Charles Gomes <charlesrg(at)outlook(dot)com> wrote:
> Hello guys,
>
> I've been finding performance issues when using a trigger to modify inserts on a partitioned table.
> If using the trigger the total time goes from 1 Hour to 4 hours.
>
> The trigger is pretty simple:
>
> CREATE OR REPLACE FUNCTION quotes_insert_trigger()
> RETURNS trigger AS $$
> BEGIN
> EXECUTE 'INSERT INTO quotes_'|| to_char(new.received_time,'YYYY_MM_DD') ||' VALUES (($1).*)' USING NEW ;
> RETURN NULL;
> END;
> $$
> LANGUAGE plpgsql;
>
> I've seen that some of you guys have worked on writing triggers in C.
>
> Does anyone have had an experience writing a trigger for partitioning in C ?
>
> If you have some code to paste so I can start from I will really appreciate.
Honestly I'd leave the trigger alone and modify the client code in
performance sensitive places to insert directly to the correct
partition table.
merlin
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Pavel Stehule | 2012-12-21 16:40:08 | Re: Writing Trigger Functions in C |
| Previous Message | Dimitri Fontaine | 2012-12-21 16:35:52 | Re: Event Triggers: adding information |