14

我正在研究面向数据库的 Web 应用程序中的情况,当人们应该依赖于客户端的表排序而不是服务器端的排序时。困扰我的一种特殊情况是分页。

当尝试对大表(比如 10000 行)进行分页以及按特定列对其进行排序时,最好的方法是什么?

我了解与此相关的一些问题是:

  • 我不能一次将整个表返回到客户端
  • 我无法使用 javascript 对多达 10000 条记录进行排序
  • 对表格进行排序将涉及对所有页面中的行进行排序,而不仅仅是当前页面。

那么您还有其他问题要添加到此列表中吗?

什么方法会导致客户端和服务器端交互的良好组合,从而最小化服务器负载?


添加:

好的,对数据库进行排序并返回 reqd 页面、上一页和下一页似乎是最好的选择。

现在考虑一下:

用户在按序列号排序的表格的第 3 页(共 10 页)上。现在用户单击名为“用户名”的标题,希望按用户名对表进行排序。

问题:最终结果应该是“按用户名排序的第 1 页(共 10 页)”还是“按用户名排序的第 3 页(共 10 页)”?

我知道这是一个非常主观的问题,但是您会推荐什么以及为什么?

4

4 回答 4

5

客户端最好保持简单:Javascript 排序/分页仅适用于非常小的结果集 - 足够小,用户不会注意到性能下降。

服务器端是您可以优化服务器负载的地方:

负载可以以频繁请求更多页面、每页大量行/列以及频繁请求重新排序的形式出现。(我们甚至还没有谈到过滤)

因此,根据您的用户和实际使用情况,您可能需要某种形式的缓存。请注意,这些是在您知道用户在做什么之后的一段时间内的建议:

  • 对于频繁的页面请求,考虑让一些 Ajax 请求预加载接下来的几个(和以前的)页面,然后根据用户请求将行(通过 Javascript)交换到表中。

  • 对于较大的页面大小,请考虑将行保存在“最近使用的”应用程序(内存)缓存中,这样数据库就不需要一遍又一遍地吐出相同的大块数据。

  • 对于频繁使用,一个好的方法是在 SQL 中保留一个只包含结果的缓存表。

并且总是,总是,总是适当地索引数据库。


补充回复:

我非常主观的反应是:用户(我)想从任意页面排序。让他们(我)。没有什么比在你想去的地方更烦人的了,让一个应用程序让你回到列表的开头。

另一个考虑是多级排序:你想实现按序号排序,然后是用户名吗?考虑 Microsoft Excel 的功能,或您的用户熟悉的任何其他应用程序。您的用户可能会对他们习惯的内容感到满意 - 包括被扔回第 1 页。

于 2009-06-23T06:48:08.813 回答
3

数据库在数据排序和选择方面是真正的野兽。所以你最好的选择肯定是让客户端对服务器说,“我想要页面 X,其中 Y 行按 Z 排序。” 然后数据库做它的事情,客户端显示结果。为了提高性能,您可以让您的客户端缓存结果,此外,您可以在获取当前页面之后让您的代码请求下一页和上一页,以便可以在请求时立即显示它们。

于 2009-06-23T06:37:20.190 回答
1

最好的方法是在数据库级别进行排序和分页,只返回原始数据的一个子集,这些数据只会显示在屏幕上。在这种情况下没有 javascript。

如果由于某些原因您无法在数据库级别进行排序和分页,那么您应该使用服务器端脚本来完成。在这种情况下也没有 javascript。

最糟糕的方法是使用 javascript 进行排序和分页,出于显而易见的原因,这当然是不推荐的。

于 2009-06-23T06:39:16.083 回答
0

让数据库对传递到屏幕上特定页面的内容进行排序。 它几乎总是更快,被缓存并减轻浏览器上的这种负载。

如果您愿意,如果数据足够详细并且可以从中受益,则让客户端允许通过 javascript 等进行进一步的子排序。 您可能希望存储选择了哪些子排序功能,以便在页面之间记住它们。

于 2009-06-23T06:39:55.083 回答