当前位置: 首页 > news >正文

网站建设综合软件属于网站开发吗

网站建设综合,软件属于网站开发吗,网络公司如何建网站,怎么设计网页背景图片在处理大数据表时#xff0c;分页查询是非常常见的需求。分页不仅可以提高用户体验#xff0c;还能有效减少数据库查询返回的数据量#xff0c;避免一次性加载大量记录引起的性能瓶颈。 然而#xff0c;在数据量较大或复杂查询中#xff0c;简单的分页方式可能导致性能下降…在处理大数据表时分页查询是非常常见的需求。分页不仅可以提高用户体验还能有效减少数据库查询返回的数据量避免一次性加载大量记录引起的性能瓶颈。 然而在数据量较大或复杂查询中简单的分页方式可能导致性能下降。本文将探讨 SQL 中实现分页查询的不同方式并对比它们的优缺点帮助优化大数据量场景下的分页方案。 一、分页查询的常见方式 1. 基本分页方式LIMIT OFFSET 语法 SELECT * FROM orders ORDER BY order_date DESC LIMIT 10 OFFSET 20; -- 跳过前 20 条返回第 21~30 条说明LIMIT 指定返回的行数OFFSET 指定跳过的行数。 2. 使用 ROW_NUMBER() 进行分页 适用数据库MySQL 8.0 及以上、SQL Server、PostgreSQL语法 WITH ordered_orders AS ( SELECT order_id, order_date, ROW_NUMBER() OVER (ORDER BY order_date DESC) AS rn FROM orders ) SELECT * FROM ordered_orders WHERE rn BETWEEN 21 AND 30;说明 ROW_NUMBER() 为每一行分配唯一编号可通过 WHERE 进行分页筛选。分页不受数据量影响性能稳定。 3. 游标分页基于主键或唯一索引 适用场景持续查询下一页数据适合前端“加载更多”方式。语法 SELECT * FROM orders WHERE order_date 2024-01-01 00:00:00 ORDER BY order_date DESC LIMIT 10;说明 基于主键或时间字段进行分页避免大偏移量问题性能更优。适合按时间或 ID 递增的分页加载避免全表扫描。 4. 使用 SQL_CALC_FOUND_ROWS 计算总数 语法 SELECT SQL_CALC_FOUND_ROWS * FROM orders LIMIT 10 OFFSET 20; SELECT FOUND_ROWS();说明 查询结果同时计算总行数减少一次额外的 COUNT(*) 查询。在 MySQL 8.0 以后不推荐效率较低。 二、实战案例大数据分页方案设计与优化 案例 1简单分页LIMIT OFFSET 需求描述 查询订单表中按下单日期排序的第 1001-1020 条订单记录。 SQL 实现 SELECT order_id, customer_id, order_date FROM orders ORDER BY order_date DESC LIMIT 20 OFFSET 1000;优点 简单直接适合小数据量分页。 缺点 当 OFFSET 较大时如 100000性能下降显著。数据量越大查询速度越慢因为数据库仍需扫描前 OFFSET 行。 案例 2使用 ROW_NUMBER() 实现分页 需求描述 查询订单表中按订单金额降序排列的第 51-60 条记录。 SQL 实现 WITH cte_orders AS ( SELECT order_id, amount, ROW_NUMBER() OVER (ORDER BY amount DESC) AS rn FROM orders ) SELECT * FROM cte_orders WHERE rn BETWEEN 51 AND 60;优点 即使数据量大ROW_NUMBER() 也能有效避免大偏移量问题。使用 CTE公用表表达式代码更清晰。 缺点 需要 SQL 8.0 以上版本或其他支持窗口函数的数据库。 案例 3游标方式分页基于索引分页 需求描述 查询比上次加载时间更早的订单记录每次加载 20 条记录。 SQL 实现 SELECT order_id, customer_id, order_date FROM orders WHERE order_date 2024-05-01 00:00:00 ORDER BY order_date DESC LIMIT 20;优点 不依赖 OFFSET即使数据量大也能快速查询。可动态加载下一页避免重复数据查询。 缺点 需要前端记录上一页最后一条数据的时间或 ID。 案例 4SQL_CALC_FOUND_ROWS 计算总记录数 需求描述 查询订单表第 21-40 条记录同时返回总记录数用于前端分页展示。 SQL 实现 SELECT SQL_CALC_FOUND_ROWS order_id, customer_id FROM orders ORDER BY order_date DESC LIMIT 20 OFFSET 20; SELECT FOUND_ROWS();优点 无需额外执行 COUNT(*) 查询减少一次数据库交互。 缺点 MySQL 8.0 开始弃用SQL_CALC_FOUND_ROWS 效率较低。 三、性能对比与优化策略 1. 性能对比 方式性能表现小数据性能表现大数据复杂性推荐场景LIMIT OFFSET高低简单小数据量、简单分页ROW_NUMBER()高高一般大数据量分页、多层次筛选游标分页高高较复杂无限加载、动态分页SQL_CALC_FOUND_ROWS中低简单需要总行数时不推荐大数据量 2. 大数据分页优化策略 避免深度分页 限制最大 OFFSET提供“跳页”或“前端加载更多”方式。使用游标或基于索引的分页方式逐步加载数据。 索引优化 在分页查询涉及的字段上建立索引提高数据检索效率。 CREATE INDEX idx_order_date ON orders(order_date);改用 ROW_NUMBER() 对于复杂多条件查询使用窗口函数如 ROW_NUMBER()替代 LIMIT OFFSET能有效避免性能下降问题。 提前过滤数据 分页前尽可能过滤不必要的数据减少扫描行数。 SELECT * FROM orders WHERE status completed ORDER BY order_date DESC LIMIT 20 OFFSET 2000;四、总结 小数据量分页使用 LIMIT OFFSET 简单高效。大数据量分页优先选择游标或基于索引的分页方式减少 OFFSET 扫描行数。复杂分页使用 ROW_NUMBER() 结合 CTE 实现多层次分页性能稳定推荐大数据环境下使用。动态加载基于唯一索引或时间字段的游标分页方式在实际业务中更具实用性避免性能瓶颈。
http://www.hkea.cn/news/14412516/

相关文章:

  • 做一家网站的成本做外贸需要关注的网站有什么问题
  • 北京品牌建设网站公司排名下载中国移动app免费下载安装
  • 广州市建设集团网站首页wap网站部署
  • 网站建设可以在家做吗好的高端企业网站建设公司
  • dw设计做网站完整案例网络服务提供者应当将该声明转送发出通知的权利人
  • python搭建个人网站搜索引擎营销优化策略有哪些
  • 网站建设51cto手机上可视化编程app
  • 科技类网站安徽新网讯科技发展有限公司
  • 网站平台建设镜像站wordpress
  • 建站公司费用wordpress戏
  • 手机网站模板开发wordpress 大图主题
  • 专业的会议网站建设龙华区民治街道
  • 网站外链建设策略app开发与网站开发有何不同
  • 整站优化推广品牌服务器网站路径问题
  • 口碑好网站建设价格武进网站建设怎么样
  • 做网络网站需要三证么网站建设平台ui确认书
  • wordpress去掉链接中的mseo关键词排名软件流量词
  • 创建网站怎么赚钱的黄石网站建设推荐
  • 蒲公英路由做网站我想自己建立一个网站
  • 网站开发成本主要有哪些给人做网站网站犯法嘛
  • 禄劝彝族苗族网站建设建站平台 discuz
  • 大连微网站只会后端不会前端如何做网站
  • 淘宝联盟交钱建设网站酒店网站素材
  • 建立一个公司的网站昆明今天最新通知
  • 免费做网站电话学ui设计一般多少钱
  • 做视频直播类型的网站云上网站做等保
  • 钓鱼网站链接怎么做高端网站设计培训机构
  • 滁州做网站网站建设合同 域名续期
  • 中学生网站源码龙岗网站建设哪家好
  • 自己如何建设网站最近韩国电影片免费韩国在线观看