尝试做与这个问题相同的事情,但这次是在 sqlite 中。在我当前的应用程序中,我需要能够执行这种类型的查询:
SELECT First, Last, Score
FROM mytable
WHERE
('John', 'Jordan', 5) <= (First, Last, Score )
AND (First, Last, Score) <= ('Mike', 'Taylor', 50)
ORDER BY First, Last, Score
LIMIT 1
并得到 的答案('Liz', 'Jordan', 2)
,给定以下数据:
+-------+---------+-------+
| First | Last | Score |
+-------+---------+-------+
| Liz | Jordan | 2 |
| John | Jordan | 2 |
| Liz | Lemon | 10 |
| Mike | Taylor | 100 |
| John | Jackson | 1000 |
| Mike | Wayne | 1 |
| Liz | Lemon | 20 |
| Liz | Meyers | 5 |
| Bruce | Jackson | 1 |
+-------+---------+-------+
在 sqlite 中完成此任务的最有效方法是什么?请记住,这是一个玩具示例,并且我的实际应用程序具有包含更多列和数据类型以及数亿行的表。
如果解决方案很容易扩展到更多/更少的列,那就更好了。
元组比较:
元组是按字典顺序排列的,这意味着序列的顺序与它们的第一个不同元素相同。例如,(1,2,x) < (1,2,y) 返回的结果与 x < y 相同。
值得注意的是,SQL-92(以及 mysql、oracle、postresql)正确地实现了这一点。该标准使用“行值构造函数”来表示我所说的元组。该行为在第 8.2.7 部分,第 209 页中详细定义。
这是创建示例所需的 SQL:
create table mytable ( First char(20), Last char(20), Score int );
insert into mytable values ('Liz', 'Jordan', 2);
insert into mytable values ('John', 'Jordan', 2);
insert into mytable values ('Liz', 'Lemon', 10);
insert into mytable values ('Mike', 'Taylor', 100);
insert into mytable values ('John', 'Jackson', 1000);
insert into mytable values ('Mike', 'Wayne', 1);
insert into mytable values ('Liz', 'Lemon', 20);
insert into mytable values ('Liz', 'Meyers', 5);
insert into mytable values ('Bruce', 'Jackson', 1);
create unique index 'UNIQ' on mytable (First, Last, Score);