EF Core 统计当前月创建的数据数量(DateTimeOffset 类型)效率最高的方法是什么?

2022-10-18 15:36:21 +08:00
 edis0n0
746 次点击
所在节点    数据库
5 条回复
Chad0000
2022-10-18 15:39:13 +08:00
这种统计功能其实可以考虑写表定时刷新,这样性能就无所谓了
edis0n0
2022-10-18 15:42:25 +08:00
@Chad0000 #1 查询频率其实不高,目前是直接 Where 和月第一天时间比大小,感觉很慢,不知道是不是遍历了全表,想问问要不要加索引。
wu00
2022-10-18 16:25:26 +08:00
1 ,要加索引
2 ,DateTimeOffset 应该会存时区信息,EF 生成的 sql 扒出来看看执行计划,使用某些函数(比如 date_fromat)转换时间,从而导致索引失效
clorischan
2022-10-18 19:09:32 +08:00
ID 是自增类型或者带时间戳的雪花 ID 或者是有序 GUID 的话,可以试试先找当月第一条数据,然后再查询 ID 大于这条的数据。
u823tg
2022-10-19 06:42:45 +08:00
效率最高就是实时计数,或者定时计数,然后写表。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/887795

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX