python – Sqlite3比grep慢约6倍

python – Sqlite3比grep慢约6倍,第1张

概述我有一个188万行的表和一个188万行的文本文件,如下所示: CREATE TABLE trigram (count integer, A text, B text, C text)time echo 'select * from trigram where C="mailman";'|sqlite3 3g.db18.419 seconds.time grep 'mailman$' N-Gr 我有一个188万行的表和一个188万行的文本文件,如下所示:

CREATE table trigram (count integer,A text,B text,C text)time echo 'select * from trigram where C="mailman";'|sqlite3 3g.db18.419 seconds.time grep 'mailman$' N-Grams/3g3.137 seconds

或者更复杂的查询

time grep 'the [^ ]* mailman$' N-Grams/3g 2.879 secondstime echo 'select * from trigram where A="the" and C="mailman";'|sqlite3 3g.db15.839 seconds

有什么方法可以加快sqlite3的速度吗?

解决方法 创建索引:

CREATE INDEX IDx_trigram_col_c ON trigram(C);

然后再试一次.

您可以使用覆盖索引在第二个查询上获得更快的速度:

CREATE INDEX IDx_trigram_col_c ON trigram(C,A);

要么

CREATE INDEX IDx_trigram_col_c ON trigram(A,C);

(如果列具有不同的分布,则首先使用更多的值).

总结

以上是内存溢出为你收集整理的python – Sqlite3比grep慢约6倍全部内容,希望文章能够帮你解决python – Sqlite3比grep慢约6倍所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1193226.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存