- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在亚马逊 EC2 服务器上的 ubuntu (12.04 LTS) 上运行 postgres (9.1)。我有这张 table :
Table "public.principal_component"
Column | Type | Modifiers
---------------+------------------+-----------
eigenvalue_id | integer | not null
stm_id | integer | not null
value | double precision |
Indexes:
"principal_component_pk" PRIMARY KEY, btree (eigenvalue_id, stm_id)
"pc_eigval_index" btree (eigenvalue_id)
Foreign-key constraints:
"principal_component_eigenvalue_id_fkey" FOREIGN KEY (eigenvalue_id) REFERENCES
eigenvalue(id)
"principal_component_stm_id_fkey" FOREIGN KEY (stm_id) REFERENCES stm(id)
编辑:此表包含 69,789,400 行。
我尝试运行这个查询:
select count(*) from principal_component where eigenvalue_id >= 801 and
eigenvalue_id <= 900
但真的花了很长时间,所以我取消了。因此,我使用 bash 对上述查询范围内的每个 id 值运行查询:
time for ((a = 801; a <= 900; a++))
do
command="select count(*) from principal_component where eigenvalue_id=$a"
sudo -u postgres psql text_analytics -c "$command"`
done
这个 bash 命令总共花费了 16 秒(对于所有 100 个单独的查询加上显示等)。
然后我重新运行第一个查询,并计时:它用了 250 秒。
编辑:查询结果为 0 - 计数为 0(如我所料)
为什么会出现差异?以下是每个查询的解释计划结果:快速、个性化的查询:
explain analyze select count(*) from principal_component where eigenvalue_id = 801"
QUERY PLAN
-----------------------------------------------------------------------------------
Aggregate (cost=168209.10..168209.11 rows=1 width=0) (actual time=13.367..13.369
rows=1 loops=1)
-> Index Scan using pc_eigval_index on principal_component (cost=0.00..167883.16
rows=130377 width=0) (actual time=13.344..13.344 rows=0 loops=1)
Index Cond: (eigenvalue_id = 801)
Total runtime: 13.512 ms
(4 rows)
缓慢的“组合”查询:
explain analyze select count(*) from principal_component where eigenvalue_id >= 801 and
eigenvalue_id <= 900"
QUERY PLAN
---------------------------------------------------------------------------------------
Aggregate (cost=1618222.49..1618222.50 rows=1 width=0) (actual time=774.585..774.586
rows=1 loops=1)
-> Bitmap Heap Scan on principal_component (cost=656742.39..1560409.48 rows=23125206
width=0) (actual time=774.558..774.558 rows=0 loops=1)
Recheck Cond: ((eigenvalue_id >= 801) AND (eigenvalue_id <= 900))
-> Bitmap Index Scan on pc_eigval_index (cost=0.00..650961.09 rows=23125206
width=0) (actual time=774.549..774.549 rows=0 loops=1)
Index Cond: ((eigenvalue_id >= 801) AND (eigenvalue_id <= 900))
Total runtime: 774.751 ms
(6 rows)
我对阅读计划一无所知,所以我提前为遗漏一些明显的东西道歉。提前感谢您的任何想法。
最佳答案
考虑在您的表上运行analyze
,或者如果它最近进行了大规模更新则vacuum analyze
,或者如果您已经这样做了则增加它正在收集的统计量。相差 2300 万行的估计有点太多了。
除此之外,Postgres 9.1 也无济于事。 9.2 将进行仅索引扫描,从而消除了过程中的位图索引扫描。
旁白:这些查询并非严格等同或可比。第一个需要改为:
select count(*) from ... group by igenvalue_id
关于sql - postgres : two simple, 等效查询,但一个慢得多,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20443684/
我想创建一个对象,比方说一个饼图。 class Pie def initialize(name, flavor) @name = name @flavor = flavor e
我正在寻找类似于 Log property in Linq DataContext 的功能. 最佳答案 所有执行的 SQL 都写入 Trace,因此您可以使用 TraceListener 访问。 关于
使用 django-simple-history ,如何从我的模型中获取最后更改的对象? 我尝试了 MyModel.history.most_recent(),它需要一个模型实例,因此可能会返回所选实
我定期使用 Eclipse 调试器,这一直困扰着我关于 IDE 的问题。步进过滤是一个非常宝贵的工具,这样我就不会进入没有源代码或者我根本不感兴趣的类。但是,Eclipse 在大多数情况下都没有正确处
我基于有向图构建一棵树。源数据是 SQL 表中的一系列父子关系。它肯定是一棵树(无论如何我都会验证)。我想要一组从根到每片叶子的简单路径。数据是会计“科目表”中的标题,路径类似于“根 -> Asset
我对如何在torii中使用ember-simple-auth有点困惑 我正在使用ember-cli-simple-auth和ember-cli-simple-auth-torii 我得到下面提到的错误
考虑以下用 simple-xml 注释注释的枚举: @Root(name="days") public enum DaysOfWeek { SUNDAY("blue", 30), MO
我有一个 json 文件,我正在 excel 中创建一些 vba 代码。我想用java读取这个json文件。为此,我编写了以下代码 try { Class.forName("org.j
我在尝试使用 google 的 simple-json 解析一个简单的 json 时遇到了一个奇怪的问题。 这是我的代码,它不起作用: String s = args[0].toString(); J
我正在尝试解析下面的 json 文件: {"units":[{"id":42, "title":"Hello World", "positi
我正在使用 simple-import-sort eslint 插件进行 react 。我想我的 .eslintrc.js是对的,但我无法使这个特定的插件工作。我在文件的第一行收到以下错误: 未找到规
我正在尝试解析子文件,但我不知道自己做错了什么(当然,我也不知道自己做对了什么)。 文件.json [{ "arrOne":{ "one":"a", "two":"b",
在我的Angel 16(独立的)应用程序中,我有一个简单的服务来测试LangChain和OpenAI。同样的代码在NodeJS应用程序中运行得非常好,然而,当从角度运行时,OpenAI返回的结果总是空
我正在尝试测试连接到数据库的 Web 应用程序 - 我的 Junit 代码不执行连接。 设置按照 https://github.com/h-thurow/Simple-JNDI InitialCont
我正在尝试制作一个小型应用程序,它可以通过 ISBN 在亚马逊上搜索一本书。我是 Amazon Web Service 的新手。 我正在关注以下链接: http://flyingpies.wordpr
我正在使用简单 XML 序列化 (simple-xml-2.6.6.jar) here将我的 XML 响应从 webservice 转换为 POJO 类。 XML 是:
Simple UI混合开发的必经之路~ Simple UI快速上手 在混合开发的模式下,如果想使用django admin,又嫌弃后台不符合你的审美?Simple UI给你想要的答案,我不是打广告的~
Simple JSON是Google开发的Java JSON解析框架,基于Apache协议。 下载的文件是:json_simple.jar 例子1:很方便的方式,使用JSONValue
我有一个 simple_form 表单设置,它会很好地显示内联错误。我遇到过一些用户看不到这些错误的问题,并要求在非常长的表格顶部进行清晰的枚举。我使用了 Rails 教程中的代码设置:
我正在使用简单的 XML 框架,只是重命名了一些 XML 布局,这些布局现在似乎不再起作用了。 这是我的 XML: 2 0 1
我是一名优秀的程序员,十分优秀!