0

我正在尝试将 25600 行加载到数据表中,但这大约需要 10 秒。该请求是通过 ajax API 调用。

视图.py

@api_view()
def get_all_data(request):


get_all_data_ = Data.objects.values("name","contact_number","email_address","address","age",
"location_type","sector","phase","total_data","total_usage","city","district")
                 

return JsonResponse(list(get_all_data_), safe=False)

模板.html

var table = $('#data-table').DataTable({

                serverSide: true,

                "ajax": {
                "url": "/alldata/",
                "dataSrc": ""
                },

              "columns": [

                  {"data": "name"},
                  {"data": "contact_number"},
                  {"data": "email_address"},
                  {"data": "address"},
                  {"data": "age"},
                  {"data": "location_type"},
                  {"data": "sector"},
                  {"data": "phase"},
                  {"data": "total_data"},
                  {"data": "total_usage"},
                  {"data": "city"},
                  {"data": "district"}
                 
              ],

        
          });

我怎样才能让它瞬间完成?

4

1 回答 1

1

我会做什么:

  • 我会添加分页(正如@Willem Van Onsem 建议的那样)只需加载前 100 个(例如)样本并添加链接以在表格上分页(下一个/上一个)。看看 Django Paginator
  • 如果您想显示有关整个数据集的一些信息,我将计算描述数据的统计数据并显示它而不是整个数据。例如平均值或中值...

如果你真的想用整张桌子让它更快:

  • 您可以尝试使用更快的服务器(也许会有所帮助),
  • 您可以尝试缓存它,也许将数据存储在内存中,这样您就不需要为每个请求运行数据库查询(但您需要记住刷新/验证缓存)。
于 2020-11-04T09:36:10.093 回答