如何解决在MySQL 8中,我可以创建一个索引来加快LIKE搜索的速度吗? 参考文献
我正在使用Django 3,Python 3.8和MySql8。我有以下Django模型,其中基于部分名称创建搜索...
class Coop(models.Model):
objects = CoopManager()
name = models.CharField(max_length=250,null=False)
types = models.ManyToManyField(CoopType,blank=False)
addresses = models.ManyToManyField(Address)
enabled = models.BooleanField(default=True,null=False)
phone = models.ForeignKey(ContactMethod,on_delete=models.CASCADE,null=True,related_name='contact_phone')
email = models.ForeignKey(ContactMethod,related_name='contact_email')
web_site = models.TextField()
...
# Look up coops by a partial name (case insensitive)
def find_by_name(self,partial_name):
queryset = Coop.objects.filter(name__icontains=partial_name,enabled=True)
print(queryset.query)
return queryset
上面的代码会产生此查询...
SELECT `directory_coop`.`id`,`directory_coop`.`name`,`directory_coop`.`enabled`,`directory_coop`.`phone_id`,`directory_coop`.`email_id`,`directory_coop`.`web_site` FROM `directory_coop` WHERE (`directory_coop`.`enabled` = True AND `directory_coop`.`name` LIKE %Credit%)
下面是Django迁移产生的表。我可以做些什么索引或其他调整来加快这些查询的速度,特别是“ name
之类的%Credit%”部分吗?
CREATE TABLE `directory_coop` (
`id` int NOT NULL AUTO_INCREMENT,`name` varchar(250) COLLATE utf8mb4_unicode_ci NOT NULL,`enabled` tinyint(1) NOT NULL,`phone_id` int DEFAULT NULL,`email_id` int DEFAULT NULL,`web_site` longtext COLLATE utf8mb4_unicode_ci NOT NULL,PRIMARY KEY (`id`),KEY `directory_coop_email_id_c20abcd2` (`email_id`),KEY `directory_coop_phone_id_4c7e2178` (`phone_id`),CONSTRAINT `directory_coop_email_id_c20abcd2_fk_directory_contactmethod_id` FOREIGN KEY (`email_id`) REFERENCES `directory_contactmethod` (`id`),CONSTRAINT `directory_coop_phone_id_4c7e2178_fk_directory_contactmethod_id` FOREIGN KEY (`phone_id`) REFERENCES `directory_contactmethod` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=993 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci
解决方法
使用like
运算符进行常规索引编制不会加快SQL查询的速度,但是您可以在MySQL's full-text search functions上使用FULLTEXT indexed column
为此,您需要为 name
列manually using SQL query编制索引,因为Django还没有该功能。
在FULLTEXT
列上启用 name
索引 后,可以使用the search
lookup或Django Func(...)
表达式查询数据。
参考文献
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。