mysql查询优化
mysql查询,滤除某一字段packageId(不是主键) = num的结果,是直接使用not in 好还是查询完毕遍历结果集的时候滤除好。查询完后无论怎样都需要遍历结果集。
回复内容:
mysql查询,滤除某一字段packageId(不是主键) = num的结果,是直接使用not in 好还是查询完毕遍历结果集的时候滤除好。查询完后无论怎样都需要遍历结果集。
题主在评论中补充了问题
就是考虑到索引,所以才会考虑这类查询条件会不走索引,全表查询速率会很慢。不过这个任务的数据量还是很大的。这个是给网站的一些套餐用户发送短信的提醒的功能。不等于7是因为这个套餐是免费送的,不在考虑的范围内。所以又必须去除。
对于这种大数据量的全表遍历, 首先这种全表取的方式就是不可取的, 你可以考虑通过主键id分段的形式来进行查询, 比如说, 你第一次查询 id > 0 的200条记录, 然后记录下最大id, 然后再查询 > 当前最大id的200条记录, 以此类推
在配合这种id分段的场景下, 你可以放心的把你的packageId放入查询条件, 因为肯定是走到主键id上去的, 所以mysql过滤的数据最多也就200条, 所以问题不大 (200只是举例, 你可以自己根据实际情况和服务压力进行控制)
额外还带来一个好处是你也可以实时观察当前任务的进行情况(发送了200个用户了你可以打个日志, 如果中断你也可以知道从哪里开始)
==== 以下是原答案 ===
你这个查询是没有分页的, 这里也就假定你的数据量其实非常小. 然后因为没有分页也必然会有全表扫描, 直接在sql查询时做掉好了, 没啥太大差别
另外, 只是单纯的不等于一个值, 用 !=
更加直观
如果你的查询是数据量有一点规模的, 或者其实是有分页的(只是你这里的演示代码还没写出来), 那么你应该要考虑是否有其它的带索引的查询条件来辅助你查询到你的数据, 如果没有, 那你需要考虑对于这个packageId也要考虑一下是否要加索引 (如果packageId的分布在这个表中足够分散)
select * from userPackage where packageId<>7
直接使用
第一种更快。
mysql查询速度要远快于遍历的速度的。遍历的时候循环次数越少越好。
肯定是第一种快啊,千万别把所有的数据都取出来。。。mysql受不了

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.

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

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

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.

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.

Les tableaux sont des structures de données linéaires utilisées pour traiter les données dans la programmation. Parfois, lorsque nous traitons les tableaux, nous devons ajouter de nouveaux éléments au tableau existant. Dans cet article, nous discuterons de plusieurs façons d'ajouter des éléments à la fin d'un tableau en PHP, avec des exemples de code, une sortie et une analyse de complexité du temps et de l'espace pour chaque méthode. Voici les différentes façons d'ajouter des éléments à un tableau: Utilisez des crochets [] En PHP, la façon d'ajouter des éléments à la fin d'un tableau est d'utiliser des crochets []. Cette syntaxe ne fonctionne que dans les cas où nous ne voulons ajouter qu'un seul élément. Ce qui suit est la syntaxe: $ array [] = valeur; Exemple
