mysql 数据库查询 按时间排序 如果时间一样 按主键排序怎么写 在一张表里

mysql 数据库查询 按时间排序 如果时间一样 按主键排序怎么写 在一张表里,第1张

select * from tab order by date DESC,table_id DESC。

数据库中,输入这些就可以按时间排序。

MySQL 是一个关系型数据库,由瑞典 MySQL AB 公司开发,目前属于 Oracle 旗下公司。MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

MySQL 所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策(本词条"授权政策"),它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。由于其社区版的性能卓越,搭配 PHP ,Linux和 Apache 可组成良好的开发环境,经过多年的web技术发展,在业内被广泛使用的一种web服务器解决方案之一,称之为LAMP。

-------------------------------------------方法1

select * from (

select

tablename_tmp.*,

@rownum:=@rownum+1 ,

if(time >=DATE_FORMAT(now(),'%Y-%m-%d %H:00') ,@rank:=@rank+1,@rank:=0) as rank

from (

select * from tablename order by time desc

)

tablename_tmp ,

(select @rownum :=0 , @ptime := null ,@rank:=0) a

) a

order by rank desc ,time desc

---------------------------------------方法2

select * from tablename order by 

(case when DATE_FORMAT(time ,'%k')=0 then 24 when  DATE_FORMAT(time ,'%k')*1>=DATE_FORMAT(now(),'%k')*1  then DATE_FORMAT(time ,'%k') else 25 end) ,time desc

题主测试一下?你这里的24点应该是第二天的00:00:00  。你这样排有什么用处?

用union拼接一下就行了,形如

selet * from tablename where hdtime>='2013-5-6' order by hdtime

union all

selet * from tablename where hdtime<'2013-5-6' order by hdtime desc

当然这不是标准的语法,mysql中的时间比较偶不太清楚,你要自己修改一下。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7367276.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-04
下一篇 2023-04-04

发表评论

登录后才能评论

评论列表(0条)

保存