Joe Celko s SQL for Smarties - Advanced SQL Programming P18. In the SQL database community, Joe Celko is a well-known columnist and purveyor of valuable insights. In Joe Celko's SQL for Smarties: Advanced SQL Programming, he picks up where basic SQL training and experience leaves many database professionals and offers tips, techniques, and explanations that help readers extend their capabilities to top-tier SQL programming. Although Celko denies that the book is about database theory, he nevertheless alludes to theory often to buttress his practical points. This title is not for novices, as the author points out. Instead, its intended audience. | 142 CHAPTER 4 TEMPORAL DATA TYPES IN SQL WHERE AND AND AND AND UNION SELECT FROM LotLocations AS L1 LotLocations AS L2 WHERE AND AND AND AND AND UNION SELECT FROM LotLocations AS L1 LotLocations AS L2 WHERE AND AND AND AND AND UNION SELECT FROM LotLocations AS L1 LotLocations AS L2 WHERE AND AND AND AND This query requires care to get the fourteen inequalities and the four select target lists correct. The cases where either the start times or the end times match are particularly vexing. The case where the two periods are identical . date date AND date is covered by two of the cases the first and the last. This introduces an undesired duplicate. However the union operator automatically removes duplicates so the result is correct. The Nature of Temporal Data Models 143 The downside of using union is that it does a lot of work to remove these infrequent duplicates generated during the evaluation of the join. We can replace union with union all which retains duplicates and generally runs faster. If we do that then we must also add the following to the predicate of the last case. AND NOT AND The result of this query contains two rows. lot_idlot_idpen_id from_date to_date 219 374 1 1998-02-25 1998-03-01 219 374 1 .