mysql - 按日期排序,直到达到特定日期,然后按 id DESC 排序

标签 mysql sql left-join union

基本上我有一个网站可以为高级用户提供更好的搜索功能位置,然后其他用户将紧随高级用户之后:

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) 处搜索,一旦找不到更多结果,就使用表中的其余部分。

我试过 UNION,但对 order by 不起作用,高级用户没有获得优先列表。

到目前为止,这是我的查询:

(
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 表达式中使用 CASE,它会根据条件返回一个较高(较低)的数字。使用这个作为第一个表达式来排序,如果你愿意,ID 作为第二个。

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 
       ORDER BY CASE
                  WHEN c.trust >= current_date()
                    THEN 0
                  ELSE 1
                END ASC,
                m.id DESC;

(UNION 可能不起作用,因为这消除了重复项,DBMS 可能希望对结果重新排序以这样做。也许 UNION ALL 会起作用,但随后再次不能保证。)

关于mysql - 按日期排序,直到达到特定日期,然后按 id DESC 排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50339507/

相关文章:

mysql 通过创建新表来提高性能

mysql - Sql:使用表的列值作为存储过程的参数

mysql - SQL 内部查询语法

mysql - 长时间运行的 MYSQL 查询、Frame Table 和 View with grouping

mysql - 无法在 SQL 中显示正确的列表

MySQL 嵌套或连接查询

python - 将 Pandas DataFrame 写入现有的 MySQL 数据库表

sql - 在 Microsoft SQL Server 2000 中模拟 MySQL LIMIT 子句

sql - 如何在 SQL Server 中创建 rownum

mysql - 在 Express.js 应用程序中处理 Mysql 数据库的最佳方法是什么?