小编Fer*_*Gil的帖子

MySQL按多列组合排序(不按order1 asc,field2 asc排序)

这似乎是一个典型的问题,但它有所不同.

我有一个带有id和3个时间戳字段的表(简单地说).最初所有3个字段都为空,并且它们填充了值.行的示例是:

id time1      time2      time3
1  1259625661 1259643563 null
2   null      1259621231 null
3  1259625889 null       1259644511
4   null      1259621231 null
5   null      null       1259644511
6   null      1259621231 null
7  1259625889 null       null
Run Code Online (Sandbox Code Playgroud)

我需要的是获取按最新时间戳排序的id列表(忽略它是在t​​ime1,time2还是time3).通过time1 desc,time2 desc,time3 desc执行一个命令给了我一个错误的列表,因为它首先排序所有time1字段,然后是第二个,等等...

预期结果是id的列表.

那可以在一个查询中在MySQL中完成吗?谢谢

mysql sql sql-order-by

5
推荐指数
1
解决办法
3782
查看次数

SQL计数返回一个值(而不是总数)

我需要在此查询中"单独"获取nid.

SELECT count(nid) as total,nid FROM bird_countries b group by nid order by total asc`
Run Code Online (Sandbox Code Playgroud)

基本上我需要这样做

update table set field=1 where id in (the other query);
Run Code Online (Sandbox Code Playgroud)

现在,我得到了nid和nid的总数,但是找不到如何获得nid值来使用它们.

返回第一个查询的示例是:

total nid
1     323
1     2645
1     526
2     123
Run Code Online (Sandbox Code Playgroud)

所以我只想得到值323,2645,526.实际上我不想得到123因为它的计数是2.我需要在表上设置一个字段为1,用于数是1.

更新(第二个问题):我得到了一个很好的答案,但现在我应用它时出错了.我的疑问是

update bird_countries set season="1" where nid in (SELECT nid FROM bird_countries group  by nid HAVING count(*) = 1)
Run Code Online (Sandbox Code Playgroud)

和mysql说"你不能在FORM子句中指定平板电脑目标'bird_countries'进行更新." 嗯,有没有简单/快速的方法来做到这一点?我可以复制表bird_countries并将其用于更新(稍后放弃),但可能有一种更清洁的方式.谢谢!

mysql sql count

1
推荐指数
1
解决办法
189
查看次数

标签 统计

mysql ×2

sql ×2

count ×1

sql-order-by ×1