select aa. pageId, aa.column_name,aa.layoutName, aa.section_name,aa.layout_name,aa.status,aa.column_date,
aa.layout_finish_time,aa.username,aa.userNameOne,
aa.layout_date,aa.layout_sign_time
from (select row_number() over(order by o.pageId) as rownumber,* from(
SELECT DISTINCT f.page_id pageId, c.column_name,dl.layout_name layoutName, s.section_name,l.layout_name,f.status,f.column_date,
f.layout_finish_time,su.username,lu.username userNameOne,f.layout_date,layout_sign_time
FROM newsroom…news_paper dp, newsroom…finish_record f
LEFT JOIN newsroom…news_column c ON f.column_id = c.column_id
LEFT JOIN newsroom…news_layout dl ON f.default_layout_id = dl.layout_id
LEFT JOIN newsroom…news_section s ON dl.section_id = s.section_id
LEFT JOIN newsroom…news_layout l ON f.layout_id = l.layout_id
LEFT JOIN newsroom…news_user su ON f.sign_user = su.userid
LEFT JOIN newsroom…news_user lu ON f.last_layout_user = lu.userid ) o)
aa where aa.rownumber BETWEEN 0 AND 7 and 1=1
这是一个多表联合查询 嵌套了三次
##第一次查询主是需要查出 自己所需要的数据
##第二次则是 使用rowNumber 通过唯一的Id 来进行排序 要起别名
##第三次就开始进行分页 where 别名 BETWEEN 起始位置 AND 结束位置
:起始位置 和 结束位置 就是从前台传入 的 pageNumber 和 pageSize
后台根据传入的 pageNumber 和 pageSize 来计算初始位置 和 结束位置
Integer startIndex = (pageNumber - 1) * pageSize;
Integer endIndex = pageSize;