gpt4 book ai didi

mysql - 在一个大表中搜索 varchar

转载 作者:行者123 更新时间:2023-11-29 07:52:27 26 4
gpt4 key购买 nike

我有一个包含 500 万行以上的表,并且有一个 varchar(50) 字段来保存 IP。

当我运行此查询时,需要大量资源和时间:

SELECT * FROM table WHERE ip = 'xx.xxx.xx.xxx' LIMIT 1

我可以做些什么来改进这个流程?

最佳答案

您需要在 ip 列上建立索引:

create index idx_table_ip on table(ip)

假设您没有太多重复项,那么您的查询应该会快速运行。

让我澄清一下最后的陈述。重复项不会影响该特定查询的运行时间。但是,当使用 limit 时,您应该有一个 order by,以便结果稳定(使用查询两次将返回相同的行)。在这种情况下,您应该在索引中包含 order by 列(如果可能)。否则,匹配次数会影响性能。

关于mysql - 在一个大表中搜索 varchar,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26077586/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com