Re: unique rows
От | Markus Schaber |
---|---|
Тема | Re: unique rows |
Дата | |
Msg-id | 45124343.1060005@logix-tt.com обсуждение исходный текст |
Ответ на | unique rows (TJ O'Donnell <tjo@acm.org>) |
Ответы |
Re: unique rows
|
Список | pgsql-sql |
Hi, TJ, TJ O'Donnell wrote: > So, is there a way (a constraint, a check?) that will simply > REJECT a duplicate when I insert the raw data directly into x > rather than FAILING on an error as it does > with the unique constraint above? Failing on an error is exactly the way PostgreSQL (and the SQL standard) uses to REJECT duplicates. :-) You seem to think about silently dropping the duplicates. That could be achieved with an BEFORE INSERT trigger, or with a rule on a view, as both can silently drop the inserted rule. The trigger body could even be in language SQL, along the lines of: SELECT CASE WHEN EXISTS (SELECT keycol FROM table WHERE table.keycol=NEW.keycol) THEN NULL ELSE NEW; Nevertheless, expect the insert performance to drop a little, due to the trigger overhead. The alternative approaches (SELECT'ing from the application, using a stored procedure that checks and then inserts the data, and using subtransactions to roll back the failing inserts) all seem worse (uglier and slower) to me, but don't hesitate to ask if you're interested. HTH, Markus
В списке pgsql-sql по дате отправления: