Howdy, Gordon.

This query is an attempt to replicate your items table with data just from 
changelog table.
Could you please try it out?

Best,
Oliveiros

SELECT itm_id,usr_id_create, itm_date_create, usr_id_modify, itm_date_modify
FROM
(
SELECT a.itm_id, a.usr_id as usr_id_create, create as itm_date_create
FROM  changelog  a
JOIN
(SELECT MIN(log_timestamp) as create, itm_id FROM changelog GROUP BY itm_id) b
ON (a.itm_id = b.itm_id
AND log_timestamp = create)
) subquery1
NATURAL JOIN
(
SELECT c.itm_id, usr_id as usr_id_modify, last_modified as itm_date_modify
FROM changelog c
JOIN (SELECT MAX(log_timestamp) as last_modified, itm_id FROM changelog GROUP 
BY itm_id) d
ON (d.itm_id = c.itm_id
AND c.log_timestamp = last_modified)
) subquery2





  I have a CMS with a table of items, and another table serving as a log 
  of operations performed on the items.  The revelent table structure is 
  as follows: 

  items 
  itm_id | usr_id_create | itm_date_create | usr_id_modify | 
  itm_date_modify | ..... 


  itm_id is a serial primary key. 


  usr_id_* are the keys of the users who created and last modified the 
  item. 


  item_date_* are timestamps for creation and last modification times. 


  changelog 
  itm_id | usr_id | log_timestamp | log_op 


  itm_id and usr_id are foreign keys into the respective item and user 
  tables.  log_timestamp is when the last change was made and log_op was 
  the operation performed. 


  . 


  Can anybody help with writing the query to get a view that replicates 
  the items table except with the create and last modified user IDs and 
  timestamps loaded from the changelog table?  If there is anybody who 
  has actually implemented something similar, what kind of performance 
  impact would it have? 





Reply via email to