十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
如下图:
专注于为中小企业提供网站建设、网站制作服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业南宫免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了成百上千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
图中为t_book原始数据。
按你的要求是count降序,每个lessonid仅取一条数据。
你把你的要求调整下,每个lessonid仅取一条数据,可以理解为对lessonid进行分组,按照count字段降序,即分组后取每组count的最大值。
SELECT id,a.`lessonid`,MAX(a.`count`) mc FROM t_book a GROUP BY a.`lessonid`;
如需对得出的结果按照count再次进行排序,外面加一层select,重新用下order by 进行排序就可以了。
MySQL排序 有时候很容易记混,我这里把他记录了下:
desc是降序
asc是升序(默认不写就是升序)
MySql语句:
1.带条件的排序
2.不带条件的sql直接排序
mysql不包含某个值降序输出
1、创建测试表,
create table test_order(id number, value1 number, value2 number);
2、插入测试数据
insert into test_order values(1,1001,2001);
insert into test_order values(2,1002,2002);
insert into test_order values(3,1003,2003);
insert into test_order values(4,1004,2004);
insert into test_order values(5,1005,2005);
3、查询表中所有记录数,select t.*, rowid from test_order t,
4、编写sql,按value1字段做升序,按value2字段做降序,
select t.*,
row_number() over(order by value1) rn1,
row_number() over(order by value2 desc) rn12
from test_order t
使用SQL 语句在执行查询的时候进行限制,例如,有一个字段叫做 “入库时间”,则可以:
strSql="select top 10 入库时间 from 表名 order by 入库时间 desc"
说明:top 10 就表示只显示顶部10条记录,DESC 就是降序 如果是升序,就省略 DESC 即可
我们知道从 MySQL 表中使用 SQL SELECT 语句来读取数据。
如果我们需要对读取的数据进行排序,我们就可以使用 MySQL 的 ORDER BY 子句来设定你想按哪个字段哪种方式来进行排序,再返回搜索结果。
具体语法参考:
以下是 SQL SELECT 语句使用 ORDER BY 子句将查询数据排序后再返回数据:
from 树懒学堂 - 一站式数据知识平台
你可以使用任何字段来作为排序的条件,从而返回排序后的查询结果。
你可以设定多个字段来排序。
你可以使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列。 默认情况下,它是按升序排列。
你可以添加 WHERE…LIKE 子句来设置条件。
所以,楼主所问的问题答案应该为:select ... from ... order by ID desc limit(0,5)