sql中字符串匹配问题
先上数据示例
ID | cat_id |
---|---|
1 | 1,2,4 |
2 | 2,3 |
3 | 11,13,17,19 |
4 | 3,7,9,12 |
这是某多对多关系在基于mysql的数据表中的表现形式(因为上头说应用小用两个表就算了)
并且筛选查询的要求如下表
推送条件 | 期望结果(ID) |
---|---|
1 | 1 |
1,2 | 1 |
1,3 | null |
3,9 | 4 |
3 | 2,4 |
注:推送条件和期望结果都是以
,
隔开,实际上是个一维索引数组
推送条件之间是AND
关系
目前鄙人想到的基于thinkphp
的解决方案是:
1.遍历查询结果,将cat_id化为数组
2.判断推送条件(数组形式,可以认为就是表单POST来的一维数组)是不是cat_id数组的子集。
然而问题就在遍历查询结果,这里测试是:结果如果达到6000+条,执行时间需要3~20秒左右,比较慢。
于是问一下,上表这样的筛选要求能不能用sql语句实现,从而省掉遍历的过程?
回复内容:
先上数据示例
ID | cat_id |
---|---|
1 | 1,2,4 |
2 | 2,3 |
3 | 11,13,17,19 |
4 | 3,7,9,12 |
这是某多对多关系在基于mysql的数据表中的表现形式(因为上头说应用小用两个表就算了)
并且筛选查询的要求如下表
推送条件 | 期望结果(ID) |
---|---|
1 | 1 |
1,2 | 1 |
1,3 | null |
3,9 | 4 |
3 | 2,4 |
注:推送条件和期望结果都是以
,
隔开,实际上是个一维索引数组
推送条件之间是AND
关系
目前鄙人想到的基于thinkphp
的解决方案是:
1.遍历查询结果,将cat_id化为数组
2.判断推送条件(数组形式,可以认为就是表单POST来的一维数组)是不是cat_id数组的子集。
然而问题就在遍历查询结果,这里测试是:结果如果达到6000+条,执行时间需要3~20秒左右,比较慢。
于是问一下,上表这样的筛选要求能不能用sql语句实现,从而省掉遍历的过程?
个人感觉,应该可以用sql语句实现,可以写几个存储函数,但这样一来,估计工作量上可能比多加个中间表要困难许多,而且速度上估计也快不了,建议还是建个中间表
这种集合的问题交给 redis
来做最方便不过了
127.0.0.1:6379> SADD cid_1 1
127.0.0.1:6379> SADD cid_2 1
127.0.0.1:6379> SADD cid_2 2
127.0.0.1:6379> SADD cid_3 2
127.0.0.1:6379> SADD cid_4 1
127.0.0.1:6379> SINTER cid_1 cid_2
1) "1"
127.0.0.1:6379> sinter cid_2 cid_3
1) "2"
首先谢谢大家热心的回答
然后最后采取的方案是,将关系表和其中一个存储数据比较少的简单表合并,并在此基础上用两个id区分
具体是模仿了无限子级菜单的那种建表方式

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds



PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

L'un des changements majeurs introduits dans MySQL 8.4 (la dernière version LTS en 2024) est que le plugin « MySQL Native Password » n'est plus activé par défaut. De plus, MySQL 9.0 supprime complètement ce plugin. Ce changement affecte PHP et d'autres applications

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

Si vous êtes un développeur PHP expérimenté, vous aurez peut-être le sentiment d'y être déjà allé et de l'avoir déjà fait. Vous avez développé un nombre important d'applications, débogué des millions de lignes de code et peaufiné de nombreux scripts pour réaliser des opérations.

La page est vide après que PHP se connecte à MySQL, et la raison pour laquelle la fonction Die () échoue. Lorsque vous apprenez la connexion entre PHP et la base de données MySQL, vous rencontrez souvent des choses déroutantes ...

CMS signifie Système de gestion de contenu. Il s'agit d'une application logicielle ou d'une plate-forme qui permet aux utilisateurs de créer, gérer et modifier du contenu numérique sans nécessiter de connaissances techniques avancées. Le CMS permet aux utilisateurs de créer et d'organiser facilement du contenu tel que du texte, des images, des vidéos et des documents, et de le publier sur des sites Web ou d'autres plateformes numériques.
