基本上,我有一个网站,可以为高级用户提供更好的搜索功能排名,然后其他用户将追随高级用户:
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 (高级到期日)的位置,然后再找不到更多结果,然后使用表中的其余内容。
我已经尝试了UNION,但是按订单排序不起作用,高级用户没有获得优先列表。
到目前为止,这是我的查询:
(
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,用以显示我所说的ORDER BY不起作用的含义:SQL Fiddle
当您进行选择的并集时,最后的ORDER BY将对组合的结果集进行排序。
因此,您可以简化它:
SELECT m.id, m.cid, m.title, m.price, m.images, c.trust
FROM mlisting m
JOIN companies c ON (m.cid = c.id)
WHERE m.live = 1
AND c.trust >= current_date
UNION ALL
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 m.live = 1
AND nullif(c.trust,'1970-01-01 00:00:00') is null
ORDER BY (case when c.trust >= current_date then 0 else 1 end), id DESC
请注意,使用的是UNION ALL,而不是UNION。因为当两个选择之间的日期不重叠时,不需要丢弃重复项。
后记:
这也可以在没有UNION ALL的情况下完成。
由于可以将不同的日期条件添加到单个SELECT中。
SELECT m.id, m.cid, m.title, m.price, m.images, c.trust
FROM mlisting m
LEFT JOIN companies c ON (c.id = m.cid)
WHERE m.live = 1
AND
( c.trust >= current_date
OR c.trust = '1970-01-01 00:00:00'
OR c.trust IS NULL
)
ORDER BY (case when c.trust >= current_date then 0 else 1 end), id DESC
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句