Eliminating duplicate lists
От | Richard Huxton |
---|---|
Тема | Eliminating duplicate lists |
Дата | |
Msg-id | 200308261830.31192.dev@archonet.com обсуждение исходный текст |
Список | pgsql-sql |
TIA all... Four tables: content: content_id, content_name, ... content_features: content_id, feature_id device_features: device_id,feature_id device: device_id, device_name, ... One item of content can run on many devices, providing all the required features in "content_features" correspond to those in "device_features". One device can run many content items. Now - I have functions to return compatibility for a single piece of content, but I also need to build static compatibility lists, something of the form: content_compat: content_id, compat_list_id compat_list_info: compat_list_id, compat_list_name, ... compat_list: compat_list_id, device_id What I don't want are any duplicate lists. By which, I mean if list "A" contains devices 1,2,3 then there should be no list "B" which contains 1,2,3 (and no others). Of course, new content items and devices are added regularly and shouldn't require rebuilding the entire table (just to make life interesting). Solution 1 Introduce a "compat_uniq_code" into table "compat_list_info". This would be composed of all the features supported by this list, built via plpgsql, something of the form "content-type:7:8:9" for features 7,8,9. I can then use this as a key and checking for duplicates is easy. Note that the feature ids will have to be sorted. Solution 2 Have a temporary table - build each list there and then join against compat_list and make sure that for any given compat_list_id there are either:1. items in temp_compat_list but not in compat_list2.items in compat_list but not in compat_list You could avoid the temporary table with a temporary compat_list_id and a self-join on the compat_list table. Solution 1 is a somewhat ugly procedural hack, and 2 isn't going to be a simple query and is probably going to be slow. Anyone got any better ideas? -- Richard Huxton Archonet Ltd
В списке pgsql-sql по дате отправления: