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

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

主要的作用主要确定该数据的唯一性。比如说id=1,name=张三。我们要在数据库中,找到这条数据可以使用select

*

from

where

id=1

这样就可以把张三查找出来了。而这个张三,也可以出现同名,所有用id来做主键

而你说的insert

into

是插入 *** 作。当id设置为了主键,再插入一个相同的主键值,就为报错误,并不会更新,你想要个更新就必须执行update。

-------------------------------------------方法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  。你这样排有什么用处?

select * from (select 时间1 from 表1

union all

select 时间2 from 表2

…………

union all

select 时间N from 表N) as 表名

我只是简单写了一下,查询的是一个字段,要是你的表的字段是完全一样的话,就可以用 * 代替,要是不一样的话,可以手动按照顺序写对应的字段,要是字段个数不一样多的话,可以用''代替没有的字段,不知到我说的能否明白?


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存