0

如果您了解 sakila 示例数据库,那么选择用户当前租用的项目的语句是什么。如果不是这里是代码解释:

CREATE TABLE IF NOT EXISTS `rentals` (
 `item_id` int(10) unsigned NOT NULL,
 `user_id` int(10) unsigned NOT NULL,
 `last_change_date` date NOT NULL,
 PRIMARY KEY  (`item_id`,`user_id`,`last_change_date`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

注意没有归还日期,这是因为最后一个租客的租用时间是不确定的,直到有人要求这个项目并且它也被无限期地转移给新的租客。一个用户可以租用多个项目,并且每个项目只有一件,因此 item_id 不能同时给两个用户。

我想按 user_id 显示当前租用的物品。

4

1 回答 1

0
SELECT r1.*
FROM   rentals r1
       LEFT JOIN rentals AS r2
         ON r1.item_id = r2.item_id
            AND r1.last_change_date < r2.last_change_date
WHERE  r2.last_change_date IS NULL  

这是一个经典的 sql 问题。答案在这里解释

使用

INSERT INTO rentals (item_id, user_id, last_change_date) VALUES (1, 1, '2009-01-01'), (1, 3, '2009-11-10'), (3, 3, '2009-02-13'), (3, 5, '2010-05-11'), (5, 5, '2010-06-04'), (7, 7, '2010-06-04'), (9, 9, '2010-06-04');

作为播放数据,要了解方法,请查看输出

SELECT r1.*,r2.*
FROM   rentals r1
       LEFT JOIN rentals AS r2
         ON r1.item_id = r2.item_id
            AND r1.last_change_date < r2.last_change_date

+---------+---------+------------------+---------+---------+------------------+
| item_id | user_id | last_change_date | item_id | user_id | last_change_date |
+---------+---------+------------------+---------+---------+------------------+
|       1 |       1 | 2009-01-01       |       1 |       3 | 2009-11-10       | 
|       1 |       3 | 2009-11-10       |    NULL |    NULL | NULL             | 
|       3 |       3 | 2009-02-13       |       3 |       5 | 2010-05-11       | 
|       3 |       5 | 2010-05-11       |    NULL |    NULL | NULL             | 
|       5 |       5 | 2010-06-04       |    NULL |    NULL | NULL             | 
|       7 |       7 | 2010-06-04       |    NULL |    NULL | NULL             | 
|       9 |       9 | 2010-06-04       |    NULL |    NULL | NULL             | 
+---------+---------+------------------+---------+---------+------------------+

前 3 列引用r1's 列,后 3 列引用r2's。

如您所见,只要没有r2.last_change_date大于r1.last_change_date的值,则该值为 NULL。这些r1.last_change_date是最大的行。所以要找到你想要的行,你使用条件

WHERE  r2.last_change_date IS NULL  
于 2010-06-04T12:00:55.690 回答