Table des matières
Aujourd'hui, jetons un coup d'œil au processus d'exécution d'une instruction de mise à jour avec la colonne tutoriel vidéo mysql. " >Aujourd'hui, jetons un coup d'œil au processus d'exécution d'une instruction de mise à jour avec la colonne tutoriel vidéo mysql.
Maison base de données tutoriel mysql Comment SQL est exécuté dans la base de données MySQL

Comment SQL est exécuté dans la base de données MySQL

Nov 09, 2020 pm 05:20 PM
mysql数据库 sql

Aujourd'hui, jetons un coup d'œil au processus d'exécution d'une instruction de mise à jour avec la colonne tutoriel vidéo mysql.

Comment SQL est exécuté dans la base de données MySQL

Un ensemble de processus d'exécution pour les instructions de requête et les instructions de mise à jour passera également par les mêmes étapes. Ci-dessous, nous comparons ceux de la. dernier article Jetons un bref coup d'œil à l'image :

<img src=" data- style="max-width:90%" data- style="max-width:90%">

Tout d'abord, vous devez vous connecter à la base de données avant d'exécuter l'instruction. C'est le travail du connecteur dans. la première étape.Nous avons également dit précédemment : Lorsqu'une table est mise à jour, le cache de requêtes associé à cette table deviendra invalide, nous ne recommandons donc généralement pas le cache de requêtes d'octobre.

Ensuite, l'analyseur procédera à l'analyse syntaxique et à l'analyse lexicale. Après avoir su qu'il s'agit d'une instruction de mise à jour, l'optimiseur décide quel index utiliser, puis l'exécuteur est responsable de l'exécution spécifique. ligne, puis effectuez la mise à jour.

Différent de la mise à jour de l'instruction de requête, le processus de mise à jour implique également deux journaux importants. Nous l'avons également introduit dans l'article précédent. Si vous êtes intéressé, vous pouvez trouver l'article de la semaine dernière "Deux journaux importants de MySQL". . "Un système de journalisation", je ne le présenterai pas beaucoup ici.

Ce qui suit est un exemple simple pour analyser le processus d'opération de mise à jour.

On crée d'abord une table avec un ID de clé primaire et un champ entier c :

mysql> create table demo T (ID int primarty ,c int);复制代码
Copier après la connexion

Puis on ajoute 1 à la valeur de la ligne avec ID=2

mysql> update table demo set c = c + 1 where ID = 2;复制代码
Copier après la connexion

Suivant , jetons un coup d'œil au processus d'exécution de l'instruction update. La case lumineuse dans la figure représente l'exécution dans le moteur de stockage et la case colorée représente l'exécution dans l'exécuteur.

On voit qu'à la fin, l'écriture du redolog se divise en deux étapes, préparer et commettre. C'est ce qu'on appelle souvent le « commit en deux phases ».

Pourquoi le journal doit-il être « soumis en deux phases » ?

Puisque redo log et binlog sont respectivement les journaux du moteur de stockage et de l'exécuteur, ce sont deux logiques indépendantes si la soumission en deux étapes n'est pas utilisée, il y aura des problèmes quelle que soit celle qui est soumise en premier. et lequel est soumis plus tard. Jetons un coup d'œil à l'exemple ci-dessus. Supposons que la valeur actuelle de la ligne avec ID=2 soit 0. Une fois le premier journal écrit pendant le processus de mise à jour, un crash se produit alors que le deuxième journal n'est pas écrit. ?

  • Écrivez d'abord redolog puis binlog. Supposons que le redolog a été écrit mais que le binlog n'a pas encore été écrit et que le processus MySQL redémarre anormalement. Nous savons qu'une fois le redolog écrit, les données peuvent être restaurées même si le système tombe en panne, donc après le redémarrage de MySQL, cette ligne sera restaurée à 1. Étant donné que le journal binaire se bloque avant d'être terminé, il n'existe pas d'instruction de ce type dans le journal binaire pour le moment. Par conséquent, lorsque le journal est sauvegardé ultérieurement, le journal binlog enregistré ne contient pas cette instruction. Lorsque nous devons restaurer des données via binlog, parce que binlog a perdu cette instruction, la valeur de la ligne restaurée est 0, ce qui est différent de la valeur de la base de données d'origine.
  • Écrivez d'abord le binlog, puis refaites le journal. Si après l'écriture du buglog, un crash se produit avant que le redo log ne soit terminé, et si la base de données plante à ce moment-là, la transaction sera invalide après la récupération, donc la valeur de cette ligne est toujours 0, mais l'instruction de mise à jour a été enregistrée. dans le journal binlog, lorsque vous devrez utiliser binlog pour restaurer des données à l'avenir, il y aura une transaction supplémentaire pour mettre à jour la valeur de 0 à 1, ce qui est différent du 0 dans la base de données d'origine.

Nous pouvons voir que si la « validation en deux phases » n'est pas utilisée, l'état de la base de données sera incohérent avec la base de données restaurée à l'aide des journaux. Bien que la probabilité d'utiliser des journaux pour récupérer des données soit relativement faible, l'utilisation la plus courante des journaux se fait lors de l'expansion de la capacité, qui est obtenue via une sauvegarde complète et un binlog. Cela peut entraîner des incohérences entre les bases de données maître-esclave en ligne.

Recommandations d'apprentissage gratuites 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)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

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)

Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Apr 17, 2024 pm 02:57 PM

HQL et SQL sont comparés dans le framework Hibernate : HQL (1. Syntaxe orientée objet, 2. Requêtes indépendantes de la base de données, 3. Sécurité des types), tandis que SQL exploite directement la base de données (1. Normes indépendantes de la base de données, 2. Exécutable complexe requêtes et manipulation de données).

Utilisation de l'opération de division dans Oracle SQL Utilisation de l'opération de division dans Oracle SQL Mar 10, 2024 pm 03:06 PM

"Utilisation de l'opération de division dans OracleSQL" Dans OracleSQL, l'opération de division est l'une des opérations mathématiques courantes. Lors de l'interrogation et du traitement des données, les opérations de division peuvent nous aider à calculer le rapport entre les champs ou à dériver la relation logique entre des valeurs spécifiques. Cet article présentera l'utilisation de l'opération de division dans OracleSQL et fournira des exemples de code spécifiques. 1. Deux méthodes d'opérations de division dans OracleSQL Dans OracleSQL, les opérations de division peuvent être effectuées de deux manières différentes.

Comparaison et différences de syntaxe SQL entre Oracle et DB2 Comparaison et différences de syntaxe SQL entre Oracle et DB2 Mar 11, 2024 pm 12:09 PM

Oracle et DB2 sont deux systèmes de gestion de bases de données relationnelles couramment utilisés, chacun possédant sa propre syntaxe et ses propres caractéristiques SQL. Cet article comparera et différera la syntaxe SQL d'Oracle et de DB2, et fournira des exemples de code spécifiques. Connexion à la base de données Dans Oracle, utilisez l'instruction suivante pour vous connecter à la base de données : CONNECTusername/password@database Dans DB2, l'instruction pour vous connecter à la base de données est la suivante : CONNECTTOdataba.

Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Feb 26, 2024 pm 07:48 PM

Interprétation des balises SQL dynamiques MyBatis : explication détaillée de l'utilisation des balises Set MyBatis est un excellent cadre de couche de persistance. Il fournit une multitude de balises SQL dynamiques et peut construire de manière flexible des instructions d'opération de base de données. Parmi elles, la balise Set est utilisée pour générer la clause SET dans l'instruction UPDATE, qui est très couramment utilisée dans les opérations de mise à jour. Cet article expliquera en détail l'utilisation de la balise Set dans MyBatis et démontrera ses fonctionnalités à travers des exemples de code spécifiques. Qu'est-ce que Set tag Set tag est utilisé dans MyBati

Que signifie l'attribut d'identité dans SQL ? Que signifie l'attribut d'identité dans SQL ? Feb 19, 2024 am 11:24 AM

Qu'est-ce que l'identité en SQL ? Des exemples de code spécifiques sont nécessaires. En SQL, l'identité est un type de données spécial utilisé pour générer des nombres à incrémentation automatique. Il est souvent utilisé pour identifier de manière unique chaque ligne de données dans une table. La colonne Identité est souvent utilisée conjointement avec la colonne clé primaire pour garantir que chaque enregistrement possède un identifiant unique. Cet article détaillera comment utiliser Identity et quelques exemples de code pratiques. La manière de base d'utiliser Identity consiste à utiliser Identit lors de la création d'une table.

Pratique de développement PHP : utilisez PHPMailer pour envoyer des e-mails aux utilisateurs de la base de données MySQL Pratique de développement PHP : utilisez PHPMailer pour envoyer des e-mails aux utilisateurs de la base de données MySQL Aug 05, 2023 pm 06:21 PM

Pratique de développement PHP : utilisez PHPMailer pour envoyer des e-mails aux utilisateurs de la base de données MySQL Introduction : Dans la construction de l'Internet moderne, l'e-mail est un outil de communication important. Qu’il s’agisse d’enregistrement d’utilisateur, de réinitialisation de mot de passe ou de confirmation de commande en e-commerce, l’envoi d’emails est une fonction essentielle. Cet article explique comment utiliser PHPMailer pour envoyer des e-mails et enregistrer les informations de courrier électronique dans le tableau d'informations utilisateur de la base de données MySQL. 1. Installez la bibliothèque PHPMailer PHPMailer est

Comment résoudre l'erreur 5120 dans SQL Comment résoudre l'erreur 5120 dans SQL Mar 06, 2024 pm 04:33 PM

Solution : 1. Vérifiez si l'utilisateur connecté dispose des autorisations suffisantes pour accéder ou utiliser la base de données, et assurez-vous que l'utilisateur dispose des autorisations appropriées ; 2. Vérifiez si le compte du service SQL Server est autorisé à accéder au fichier spécifié ou ; dossier et assurez-vous que le compte dispose des autorisations suffisantes pour lire et écrire le fichier ou le dossier ; 3. Vérifiez si le fichier de base de données spécifié a été ouvert ou verrouillé par d'autres processus, essayez de fermer ou de libérer le fichier et réexécutez la requête ; . Essayez en tant qu'administrateur, exécutez Management Studio en tant que etc.

Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? Dec 17, 2023 am 08:41 AM

Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? L'agrégation des données et les statistiques sont des étapes très importantes lors de l'analyse des données et des statistiques. En tant que puissant système de gestion de bases de données relationnelles, MySQL fournit une multitude de fonctions d'agrégation et de statistiques, qui peuvent facilement effectuer des opérations d'agrégation de données et de statistiques. Cet article présentera la méthode d'utilisation des instructions SQL pour effectuer l'agrégation de données et les statistiques dans MySQL, et fournira des exemples de code spécifiques. 1. Utilisez la fonction COUNT pour compter. La fonction COUNT est la plus couramment utilisée.

See all articles