Table des matières
Contexte des exigences
Réalisation des exigences
UPDATE
 1. Qu'il s'agisse de UPDATE
Maison base de données tutoriel mysql Exploration approfondie des détails d'utilisation de UPDATE dans MySQL

Exploration approfondie des détails d'utilisation de UPDATE dans MySQL

Oct 11, 2022 pm 07:32 PM
mysql update

Dans MySQL, vous pouvez utiliser l'instruction UPDATE pour modifier et mettre à jour les données dans une ou plusieurs tables. L'article suivant vous aidera à explorer les détails de l'utilisation de UPDATE dans MySQL. J'espère qu'il vous sera utile.

Exploration approfondie des détails d'utilisation de UPDATE dans MySQL

Contexte des exigences

Récemment, j'ai reçu une exigence de migration de données. Les données de l'ancien système seront migrées vers le nouveau système, l'ancien système n'ajoutera plus de données commerciales et les opérations commerciales seront effectuées. sur le nouveau système

 Pour réduire l'impact de la migration, les données sont migrées par lots, ce qui signifie que l'ancien et le nouveau système fonctionneront en parallèle pendant un certain temps

 Les données ne sont pas divisées en lots selon l'identifiant range, ce qui signifie que les identifiants de chaque lot de données sont irréguliers

 De plus, afin d'assurer la correspondance entre les anciennes et les nouvelles données du système, l'identifiant du nouveau système utilise autant que possible l'identifiant de l'ancien système

Étant donné que l'identifiant de la table est auto-incrémenté dans l'ancien et le nouveau système, l'identifiant de l'ancien système peut avoir été occupé par le nouveau système lors de la migration. Il est similaire à ce qui suit

Description des exigences.

Lors de la migration des données, essayez d'utiliser autant que possible les identifiants de l'ancien système, et les identifiants conflictuels doivent être ajustés par lots

  Comment ajuster ce lot d'identifiants contradictoires, c'est exactement ce que je veux à réaliser maintenant

Mon implémentation consiste à prédéfinir un identifiant de départ basé sur la croissance des données commerciales et l'identifiant maximum actuel du nouveau système

  

  Comment dois-je écrire ceci SQL ?

Réalisation des exigences

Certains amis peuvent penser que ce n'est pas simple ?

 Ce ne sont que 5 éléments de données, cela ne peut-il pas être fait simplement en l'écrivant comme ceci

  C'est une chose si simple, mais il y a tellement de préfigurations. Savez-vous comment le faire, monsieur ?

 L'affiche s'est soudain rendu compte à ce moment-là : Mon ami, tu es tellement génial

Mais s'il y a beaucoup de données contradictoires (des centaines ou des milliers), les modifies-tu aussi une par une comme ça ?

 Si tu fais vraiment ça, je t'admire vraiment

Exploration approfondie des détails d'utilisation de UPDATE dans MySQL

 Évidemment, il y a des amis plus sensés

 Alors comment y parvenir ?

                    ifier, vous pouvez utiliser la variable locale + UPDATE  pour y parvenir, allez directement sur SQL 

   Regardons le cas réel

  table tbl_batch_update 

 Les données est le suivant

 L'effet d'exécution est le suivant

 Après la mise à jour

 Plus rigoureux

 Comment y parvenir ? Est-ce que UPDATE prend également en charge ORDER BY ?

 C'est vraiment pris en charge, comme indiqué ci-dessous

Lorsque l'affiche utilise habituellement UPDATE, il ne le combine pas avec ORDER BY, et il n'a pas non plus essayé de le combiner avec LIMIT

Cette fois, il a essayé de donner l'impression que l'affiche plus à l'aise avec UPDATE une sensation étrange, quelle devrait être sa syntaxe complète ? Lisons lentement

UPDATE

Les éléments suivants sont tous compilés sur la base des documents officiels UPDATE Statement de MySQL 8.0 Il est recommandé d'accéder directement aux documents officiels

 Syntaxe de table unique.

Avez-vous beaucoup de questions :

Syntaxe à tables multiples

Par rapport à une table unique, elle semble plus simple et ne prend pas en charge ORD ER BY et LIMIT

 LOW_PRIORITY

  Un des modificateurs de UPDATE, utilisé pour réduire la priorité de SQL

Lors de l'utilisation de LOW_PRIOR ITY, L'exécution de UPDATE sera retardé jusqu'à ce qu'aucun autre client ne lise les données de la table

 Cependant, seul le moteur de stockage du verrouillage au niveau de la table prend en charge LOW_PRIORITY. Les moteurs de stockage du verrouillage au niveau de la table incluent : MyISAM, MEMORY et . MERGE, donc le meilleur Le InnoDB couramment utilisé n'est pas pris en charge

Il existe très peu de scénarios d'utilisation, il suffit de paraître familier

 IGNORE

  L'un des modificateurs de UPDATE, utilisé pour déclarer qu'un une erreur s'est produite lors de l'exécution de SQL Méthode de traitement

  Si IGNORE n'est pas utilisé, UPDATE sera annulée si une erreur se produit lors de l'exécution, comme indiqué ci-dessous

  9002 mis à jour pour 9003 En cas de conflit de clé primaire, l'intégralité de la UPDATE est annulée, 9000 mise à jour vers 9001 sera annulée, ~ 9005 Mise à jour non effectuée  Si vous utilisez IGNORE

, ce sera Que se passe-t-il ?

 

UPDATE

Même si une erreur survient lors de l'exécution, l'exécution sera terminée et le nombre de lignes affectées sera finalement renvoyé

 Les lignes concernées dans la déclaration ci-dessus sont 2 Pouvez-vous me dire quelles sont les deux lignes qui ont été modifiées ?

 Pour plus d'informations sur IGNORE, veuillez vérifier : L'effet de IGNORE sur l'exécution des instructions

  Concernant les scénarios d'utilisation, lorsque l'ancien et le nouveau système sont parallèles et effectuent une migration de données, il peut être utilisé lorsque la clé primaire ou conflits de clés uniques. Ignorez-le simplement

 ORDER BY

Si vous connaissez le processus d'exécution de UDPATE, il sera mieux compris

  UPDATE En fait, il y a deux étapes : Check stage et Étape de mise à jour

 Traitement ligne par ligne, si une ligne satisfait à la clause WHERE, mettez à jour une ligne

 Donc, ici ORDER BY est la même chose que SELECT dans ORDER BY a le même effet

Concernant le scénario d'utilisation, vous pouvez revenir en arrière et regarder le contexte de la demande mentionné précédemment. L'erreur signalée dans le cas 1 de

IGNORE

peut en fait également être utilisée ORDER . BY

 

LIMIT

 

LIMIT row_count

est la limite de correspondance de lignes. Une fois que les lignes row_count qui satisfont à la clause WHERE sont trouvées, que ces lignes soient réellement modifiées ou non, l'instruction s'arrêtera immédiatement C'est-à-dire que

LIMIT

est limité au check phase et n'a rien à voir avec la phase de mise à jour Relation

 

Remarque : ​​​​Il y a encore une différence avec SELECT dans la syntaxe LIMIT

 

 

value DEFAULT

 

UPDATE La value de la clause SET est une expression Nous pouvons comprendre, qu'est-ce que cela DEFAULT. tu veux dire ?个 Examinons d'abord une telle question.

  Jetons un coup d'œil à SQL_MODE et exécutons SELECT @@sql_mode; et obtenons le résultat

  STRICT_TRANS_TABLES indique que le mode strict est démarré, ce qui est correct pour INSERT et UPDATE déclarations value Le contrôle sera plus strict

Si nous désactivons le mode strict et regardons les résultats de l'exécution

  name la déclaration du champ devient NOT NULL . - mode SQL strict, le réglage de name sur NULL est réussi, mais la valeur modifiée n'est pas NULL, mais la valeur par défaut de VARCHAR tapez : chaîne vide ( '')

Résumé

   1. En mode SQL strict, pour le paramétrage du champ NOT NULL NULL, une erreur sera signalée directement et la mise à jour échouera

   2. En mode SQL non strict, pour Le paramètre de champ NOT NULL NULL définira la valeur du champ à la valeur par défaut correspondant au type de champ

À propos de la valeur par défaut du type de champ, vous pouvez afficher : Valeurs par défaut du type de données

À propos de sql_mode, vous pouvez afficher : Modes SQL du serveur

Normalement, le MySQL de l'environnement généré est généralement en mode strict, donc tout le monde sait qu'il y a une valeur DEFAULT C'est suffisant

 SET field order

SQL

Je crois que tout le monde sait

Cependant, quelle sera la valeur de la colonne name dans le SQL suivant

Jetons un coup d'oeil aux résultats

  name La valeur est-elle un peu différente de celle attendue ?

  Le SET d'une seule table UPDATE s'effectue de gauche à droite, mais la multi-table UPDATE ne l'est pas. effectué dans un ordre spécifique Résumé

 1. Qu'il s'agisse de UPDATE

ou DELETE, il existe un processus de vérification d'abord et de traitement de chaque ligne après l'avoir trouvée.

 2. Le LOW_PRIORITY dans la syntaxe de UPDATE est rarement utilisé, IGNORE est utilisé occasionnellement, et ORDER BY et LIMIT sont relativement utilisés plus souvent, mais ils sont tous les deux déroutant Ripe

 3 , sql_mode est un point de connaissance relativement important et qu'il est recommandé à tout le monde de maîtriser ; pour l'environnement de production, il est fortement recommandé d'activer le mode strict

Adresse originale : https://www.cnblogs. com/youzhibing/p/16719474.html

Auteur : Qingshi Road

[Recommandations associées : Tutoriel vidéo MySQL]

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Comment optimiser les performances des requêtes MySQL en PHP ? Comment optimiser les performances des requêtes MySQL en PHP ? Jun 03, 2024 pm 08:11 PM

Les performances des requêtes MySQL peuvent être optimisées en créant des index qui réduisent le temps de recherche d'une complexité linéaire à une complexité logarithmique. Utilisez PreparedStatements pour empêcher l’injection SQL et améliorer les performances des requêtes. Limitez les résultats des requêtes et réduisez la quantité de données traitées par le serveur. Optimisez les requêtes de jointure, notamment en utilisant des types de jointure appropriés, en créant des index et en envisageant l'utilisation de sous-requêtes. Analyser les requêtes pour identifier les goulots d'étranglement ; utiliser la mise en cache pour réduire la charge de la base de données ; optimiser le code PHP afin de minimiser les frais généraux.

Comment utiliser la sauvegarde et la restauration MySQL en PHP ? Comment utiliser la sauvegarde et la restauration MySQL en PHP ? Jun 03, 2024 pm 12:19 PM

La sauvegarde et la restauration d'une base de données MySQL en PHP peuvent être réalisées en suivant ces étapes : Sauvegarder la base de données : Utilisez la commande mysqldump pour vider la base de données dans un fichier SQL. Restaurer la base de données : utilisez la commande mysql pour restaurer la base de données à partir de fichiers SQL.

Comment insérer des données dans une table MySQL en utilisant PHP ? Comment insérer des données dans une table MySQL en utilisant PHP ? Jun 02, 2024 pm 02:26 PM

Comment insérer des données dans une table MySQL ? Connectez-vous à la base de données : utilisez mysqli pour établir une connexion à la base de données. Préparez la requête SQL : Écrivez une instruction INSERT pour spécifier les colonnes et les valeurs à insérer. Exécuter la requête : utilisez la méthode query() pour exécuter la requête d'insertion en cas de succès, un message de confirmation sera généré.

Comment utiliser les procédures stockées MySQL en PHP ? Comment utiliser les procédures stockées MySQL en PHP ? Jun 02, 2024 pm 02:13 PM

Pour utiliser les procédures stockées MySQL en PHP : Utilisez PDO ou l'extension MySQLi pour vous connecter à une base de données MySQL. Préparez l'instruction pour appeler la procédure stockée. Exécutez la procédure stockée. Traitez le jeu de résultats (si la procédure stockée renvoie des résultats). Fermez la connexion à la base de données.

Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Dec 09, 2024 am 11:42 AM

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

Comment créer une table MySQL en utilisant PHP ? Comment créer une table MySQL en utilisant PHP ? Jun 04, 2024 pm 01:57 PM

La création d'une table MySQL à l'aide de PHP nécessite les étapes suivantes : Connectez-vous à la base de données. Créez la base de données si elle n'existe pas. Sélectionnez une base de données. Créer un tableau. Exécutez la requête. Fermez la connexion.

KDE Plasma 6.1 apporte de nombreuses améliorations au populaire bureau Linux KDE Plasma 6.1 apporte de nombreuses améliorations au populaire bureau Linux Jun 23, 2024 am 07:54 AM

Après plusieurs pré-versions, l'équipe de développement de KDE Plasma a dévoilé le 28 février la version 6.0 de son environnement de bureau pour les systèmes Linux et BSD, utilisant pour la première fois le framework Qt6. KDE Plasma 6.1 est désormais livré avec un certain nombre de nouvelles fonctionnalités

La différence entre la base de données Oracle et MySQL La différence entre la base de données Oracle et MySQL May 10, 2024 am 01:54 AM

La base de données Oracle et MySQL sont toutes deux des bases de données basées sur le modèle relationnel, mais Oracle est supérieur en termes de compatibilité, d'évolutivité, de types de données et de sécurité ; tandis que MySQL se concentre sur la vitesse et la flexibilité et est plus adapté aux ensembles de données de petite et moyenne taille. ① Oracle propose une large gamme de types de données, ② fournit des fonctionnalités de sécurité avancées, ③ convient aux applications de niveau entreprise ; ① MySQL prend en charge les types de données NoSQL, ② a moins de mesures de sécurité et ③ convient aux applications de petite et moyenne taille.

See all articles