mysql 按小时查询注册用户数, 分页查询问题

MySql 码拜 8年前 (2017-04-10) 1268次浏览
select 
YMD,
sum(if(H="00",1,null)) AS H00,
sum(if(H="01",1,null)) AS H01,
sum(if(H="02",1,null)) AS H02,
sum(if(H="03",1,null)) AS H03,
sum(if(H="04",1,null)) AS H04,
sum(if(H="05",1,null)) AS H05,
sum(if(H="06",1,null)) AS H06,
sum(if(H="07",1,null)) AS H07,
sum(if(H="08",1,null)) AS H08,
sum(if(H="09",1,null)) AS H09,
sum(if(H="10",1,null)) AS H10,
sum(if(H="11",1,null)) AS H11,
sum(if(H="12",1,null)) AS H12,
sum(if(H="13",1,null)) AS H13,
sum(if(H="14",1,null)) AS H14,
sum(if(H="15",1,null)) AS H15,
sum(if(H="16",1,null)) AS H16,
sum(if(H="17",1,null)) AS H17,
sum(if(H="18",1,null)) AS H18,
sum(if(H="19",1,null)) AS H19,
sum(if(H="20",1,null)) AS H20,
sum(if(H="21",1,null)) AS H21,
sum(if(H="22",1,null)) AS H22,
sum(if(H="23",1,null)) AS H23
from (
	select ID,DATE_FORMAT(regtime, "%H") as H, DATE_FORMAT(regtime, "%Y-%m%-%d") as YMD from `fish`.`player_basic`
) t
GROUP by YMD
ORDER BY YMD DESC

这个语句要怎么样 分页查询, 统计总记录数
id  regtime

解决方案

20

select * from x order id desc limit 100,20

20

子查询跟一般查询一样  count() 来统计总数  limit来限制每页显示条数 没什么区别

20

引用:
Quote: 引用:

select * from x order id desc limit 100,20

本人不很懂,看不太明白,能详细一点吗? 麻烦了

直接在你的语句后面加limit分页。
LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。假如给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目

20

select 
count(*) as num,
YMD,
sum(if(H="00",1,null)) AS H00,
sum(if(H="01",1,null)) AS H01,
sum(if(H="02",1,null)) AS H02,
sum(if(H="03",1,null)) AS H03,
sum(if(H="04",1,null)) AS H04,
sum(if(H="05",1,null)) AS H05,
sum(if(H="06",1,null)) AS H06,
sum(if(H="07",1,null)) AS H07,
sum(if(H="08",1,null)) AS H08,
sum(if(H="09",1,null)) AS H09,
sum(if(H="10",1,null)) AS H10,
sum(if(H="11",1,null)) AS H11,
sum(if(H="12",1,null)) AS H12,
sum(if(H="13",1,null)) AS H13,
sum(if(H="14",1,null)) AS H14,
sum(if(H="15",1,null)) AS H15,
sum(if(H="16",1,null)) AS H16,
sum(if(H="17",1,null)) AS H17,
sum(if(H="18",1,null)) AS H18,
sum(if(H="19",1,null)) AS H19,
sum(if(H="20",1,null)) AS H20,
sum(if(H="21",1,null)) AS H21,
sum(if(H="22",1,null)) AS H22,
sum(if(H="23",1,null)) AS H23
from (
    select ID,DATE_FORMAT(regtime, "%H") as H, DATE_FORMAT(regtime, "%Y-%m%-%d") as YMD from `fish`.`player_basic`
) t
GROUP by YMD
ORDER BY YMD DESC

查询处的num字段就是综述

select 
YMD,
sum(if(H="00",1,null)) AS H00,
sum(if(H="01",1,null)) AS H01,
sum(if(H="02",1,null)) AS H02,
sum(if(H="03",1,null)) AS H03,
sum(if(H="04",1,null)) AS H04,
sum(if(H="05",1,null)) AS H05,
sum(if(H="06",1,null)) AS H06,
sum(if(H="07",1,null)) AS H07,
sum(if(H="08",1,null)) AS H08,
sum(if(H="09",1,null)) AS H09,
sum(if(H="10",1,null)) AS H10,
sum(if(H="11",1,null)) AS H11,
sum(if(H="12",1,null)) AS H12,
sum(if(H="13",1,null)) AS H13,
sum(if(H="14",1,null)) AS H14,
sum(if(H="15",1,null)) AS H15,
sum(if(H="16",1,null)) AS H16,
sum(if(H="17",1,null)) AS H17,
sum(if(H="18",1,null)) AS H18,
sum(if(H="19",1,null)) AS H19,
sum(if(H="20",1,null)) AS H20,
sum(if(H="21",1,null)) AS H21,
sum(if(H="22",1,null)) AS H22,
sum(if(H="23",1,null)) AS H23
from (
    select ID,DATE_FORMAT(regtime, "%H") as H, DATE_FORMAT(regtime, "%Y-%m%-%d") as YMD from `fish`.`player_basic`
) t
GROUP by YMD
ORDER BY YMD DESC limit  100

后边加上limit   就是限制查询条数 例如上述的100条


CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明mysql 按小时查询注册用户数, 分页查询问题
喜欢 (0)
[1034331897@qq.com]
分享 (0)