基本上我有一个网站,为高级用户提供更好的搜索功能定位,然后其他用户将在高级用户之后:
CREATE TABLE IF NOT EXISTS `mlisting` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`cid` int(11) NOT NULL,
`title` varchar(255) NOT NULL,
`price` decimal(9,2) NOT NULL,
`images` text NOT NULL,
`live` tinyint(1) NOT NULL DEFAULT '1',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=5 ;
INSERT INTO `mlisting` (id, cid, title, price, images, live) VALUES
(1, 1, 'title 1', 29.99, '', 1),
(2, 2, 'title 2', 69.99, '', 1),
(3, 2, 'title 3', 1.99, '', 1),
(4, 1, 'title 4', 48.99, '', 1);
CREATE TABLE IF NOT EXISTS `companies` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`trust` datetime NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=3 ;
INSERT INTO `companies` (id, trust) VALUES
(1, '1970-01-01 00:00:00'),(2, '2019-01-01 00:00:00');
因此,查询应该搜索premiumdate>=todaysdate(premium expiry day)的位置,然后在没有找到更多结果后使用表中的其余结果。
我尝试过联合,但没有工作的顺序,溢价用户没有得到优先上市。
以下是我目前的疑问:
(
SELECT
m.id, m.cid, m.title, m.price, m.images, c.trust
FROM
mlisting m
LEFT JOIN
companies c
ON (m.cid = c.id)
WHERE c.trust >='{$itsToday}' AND m.live=1
ORDER BY m.id DESC
)
UNION
(
SELECT
mo.id, mo.cid, mo.title, mo.price, mo.images, co.trust
FROM
mlisting mo
LEFT JOIN
companies co ON (mo.cid = co.id)
WHERE co.trust='1970-01-01 00:00:00' AND mo.live=1
ORDER BY mo.id DESC
)
谢谢你的关注,希望能把我引向正确的方向。
下面是一个sql fiddle,它显示了我所说的不工作的顺序:sql fiddle
2条答案
按热度按时间x8diyxa71#
当您对所选内容进行并集时,末尾的order by将对组合的结果集进行排序。
所以你可以简化它:
请注意,使用了union all,而不是union。因为当两次选择的日期不重叠时,不需要丢弃重复的。
后记:
这也可以在没有工会的情况下实现。
因为不同的日期标准可以添加到单个选择中。
k5hmc34c2#
你可以使用
CASE
在ORDER BY
表达式,根据条件返回较高(较低)的数字。使用此表达式作为第一个表达式进行排序,如果愿意,将id用作第二个表达式。(和
UNION
可能不起作用,因为这样可以消除重复项,并且dbms可能希望对结果进行重新排序。也许是一个UNION ALL
本来是可行的,但也无法保证。)