Heim Backend-Entwicklung PHP-Tutorial Eine kurze Analyse der einfachen Funktionsweise des MySQL-Sperrmechanismus durch PHP

Eine kurze Analyse der einfachen Funktionsweise des MySQL-Sperrmechanismus durch PHP

Apr 30, 2021 pm 05:16 PM
MySQL Lock -Mechanismus php

Eine kurze Analyse der einfachen Funktionsweise des MySQL-Sperrmechanismus durch PHP

Sperrmechanismus
Gemeinsame Sperre und exklusive Sperre
Gemeinsame Sperre (Lesesperre): Andere Transaktionen können lesen, aber nicht schreiben.
Exklusive Sperre (Schreibsperre): Andere Transaktionen können weder lesen noch schreiben.

Für MySQL gibt es drei Sperrebenen: Seitenebene, Tabellenebene, Zeilenebene

  • Die typische repräsentative Engine der Seitenebene ist BDB.
  • Die typische repräsentative Engine auf Zeilenebene ist INNODB.
  • Typische repräsentative Engines auf Tabellenebene sind MyISAM, MEMORY und das alte ISAM.
  • BDB-Speicher-Engine verwendet Sperren auf Seitenebene, unterstützt aber auch Sperren auf Tabellenebene.
  • InnoDB-Speicher-Engine unterstützt sowohl Sperren auf Zeilenebene (Sperren auf Zeilenebene) als auch Sperren auf Tabellenebene, standardmäßig wird jedoch Sperren auf Zeilenebene verwendet .
  • MyISAM- und MEMORY-Speicher-Engines verwenden Sperren auf Tabellenebene. Verwandte kostenlose Lernempfehlungen:
  • PHP-Programmierung
Table Shared Read Lock (Tabellenlesesperre): Es blockiert nicht die Leseanforderungen anderer Benutzer für dieselbe Tabelle, blockiert jedoch die Schreibanforderungen anderer Benutzer für dieselbe Tabelle.
Table Exclusive Write Lock (Tabellenschreibsperre); : Es blockiert die Lese- und Schreibvorgänge anderer Benutzer für dieselbe Tabelle.

MyISAM-Tabellensperrmethode:

Verwenden Sie den Befehl LOCK TABLE, um die MyISAM-Tabelle explizit zu sperren.

LOCK TABLES real_table ( READ|WRITE), insert_table (READ|WRITE); / /Lock

UNLOCK TABLES; //Unlock

  • Beispiel:
  • Zum Beispiel gibt es zwei Tabellen: Konto (ID, Name, Bargeld), Held (Nummer). , Name, Land).
Der aktuelle Prozess ändert andere Tabellen: update hero set name="ss" where number=1; wird melden, dass Tabelle „hero“ nicht mit LOCK TABLES gesperrt wurde

Der aktuelle Prozess ändert die Tabelle: update account set name="ssss" where id=1 ; meldet, dass die Tabelle „Konto“ mit einer READ-Sperre gesperrt wurde und nicht aktualisiert werden kann.

Wenn ein anderer MySQL-Prozess eintrifft, können Sie andere Tabellen und Konten abfragen, aber Sie können das Konto nicht ändern. Es wird ewig warten und die Sperre muss vor der Ausführung aufgehoben werden sofort erhalten werden
  • Table_locks_waited bezieht sich auf Sperren auf Tabellenebene, die nicht sofort erhalten werden können. Die Häufigkeit, mit der Sie auf eine Sperre warten müssen
  • 2. InnoDB-Sperrmethode:
Bei gewöhnlichen SELECT-Anweisungen fügt InnoDB keine Sperren hinzu alle Sperren;
Sperren können nur während der Transaktionsausführung verwendet werden


Die Sperren können nur während der Festschreibungsausführung verwendet werden. Oder sie werden beim Zurücksetzen freigegeben, und alle Sperren werden gleichzeitig freigegeben.

  1. Gemeinsame Sperre(n): SELECT * FROM table_name WHERE … LOCK IN SHARE MODE. Andere Sitzungen können den Datensatz weiterhin abfragen und dem Datensatz gemeinsame Sperren im Freigabemodus hinzufügen. Wenn die aktuelle Transaktion jedoch den Datensatz aktualisieren muss, führt dies wahrscheinlich zu einem Deadlock. Jeder kann es lesen, aber es kann nicht geändert werden, wenn eine der exklusiven gemeinsamen Sperren gesperrt ist.

    Exklusive Sperre (X): SELECT * FROM table_name WHERE ... FOR UPDATE. Andere Sitzungen können den Datensatz abfragen, dem Datensatz jedoch keine gemeinsame Sperre oder exklusive Sperre hinzufügen, sondern auf den Erhalt der Sperre warten. Ich möchte es ändern, aber Sie können es nicht ändern oder lesen ): SELECT * FROM table_name WHERE … FOR SHARE

    Exklusive Sperre (X): SELECT * FROM table_name WHERE … FOR UPDATE[NOWAIT|SKIP LOCKED]
  2. –NOWAIT: Ein Fehler wird sofort zurückgegeben, nachdem eine wartende Sperre gefunden wurde, ohne zu warten damit die Sperre abläuft.
–SKIP LOCKED: Überspringen Sie gesperrte Zeilen und aktualisieren Sie andere Zeilen direkt. Seien Sie jedoch vorsichtig, ob die Aktualisierungsergebnisse nicht den Erwartungen entsprechen.

2.1PHP-Vorgang

<?php/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2021/4/29 0029
 * Time: 11:20
 */$link = new mysqli(&#39;127.0.0.1&#39;, &#39;root&#39;, &#39;123&#39;, &#39;db_school&#39;); // 连接数据库if(mysqli_connect_errno()){                                // 检查连接错误
    printf("连接失败:%s<br>", mysqli_connect_error());
    exit();}//(s1)$table = "account";$type = "read";$sql1 = "LOCK TABLES $table $type";$link->query($sql1);//处理逻辑//$sql1 = "select * from $table;";        //(s1)true//$sql1 = "select * from hero;";        //false//$sql1 = "update hero set name='ss' where number=1; ";     //false$sql1 = "update account set name='ssss' where id=1;";   //false$result = $link->query($sql1);var_dump($result);sleep(20);  //测试    //假设还没释放锁,开启cmd进mysql(s2)可以查询,但不能执行更改和删除操作,会等待这边释放锁$link->query("unlock tables");    //取消全部的锁//解锁后正常操作//$result = $link -> query($sql1);//var_dump($result);$link->close();

Sehen Sie sich die Tabellen an, die gesperrt sind.
    show OPEN TABLES where In_use >

Das obige ist der detaillierte Inhalt vonEine kurze Analyse der einfachen Funktionsweise des MySQL-Sperrmechanismus durch PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So verwenden Sie PHP, um soziale Freigabefunktionen zu erstellen. PHP Sharing Interface Integration Practice So verwenden Sie PHP, um soziale Freigabefunktionen zu erstellen. PHP Sharing Interface Integration Practice Jul 25, 2025 pm 08:51 PM

Die Kernmethode zum Aufbau sozialer Freigabefunktionen in PHP besteht darin, dynamisch Freigabelinks zu generieren, die den Anforderungen jeder Plattform entsprechen. 1. Erhalten Sie zuerst die aktuelle Seite oder die angegebenen URL- und Artikelinformationen. 2. Verwenden Sie Urlencode, um die Parameter zu codieren. 3.. Spleiß und generieren Teilenverbindungen gemäß den Protokollen jeder Plattform; 4. Zeigen Sie Links im vorderen Ende an, damit Benutzer klicken und freigeben können. 5. generieren Sie Dynamik OG -Tags auf der Seite, um die Anzeige der Freigabe inhaltlich zu optimieren. 6. Achten Sie darauf, dass Sie den Benutzereingaben entkommen, um XSS -Angriffe zu verhindern. Diese Methode erfordert keine komplexe Authentifizierung, weist nur geringe Wartungskosten auf und eignet sich für die meisten Anforderungen an den Inhaltsaustausch.

PHP erstellt ein Blog-Kommentarsystem zur Monetarisierung von PHP-Kommentarbewertung und Anti-Brush-Strategie PHP erstellt ein Blog-Kommentarsystem zur Monetarisierung von PHP-Kommentarbewertung und Anti-Brush-Strategie Jul 25, 2025 pm 08:27 PM

1. Maximierung des kommerziellen Wertes des Kommentarsystems erfordert die Kombination der präzisen Lieferung native Werbung, benutzerbezahlte Wertschöpfungsdienste (z. B. Bilder hochladen, Aufladungskommentare), den Incentive-Mechanismus basierend auf der Qualität der Kommentare und der Anonymen Daten Insight-Monetarisierung von Compliance; 2. Die Prüfungsstrategie sollte eine Kombination aus dynamischer Keyword-Filterung und Benutzerkennungsmechanismen vorab der Auditing einsetzen, die durch die Qualität der Kommentarqualität ergänzt werden, um die hierarchische Inhaltsbelastung zu erreichen. 3. Die Anti-Pushing erfordert die Konstruktion einer mehrschichtigen Verteidigung: Recaptchav3 sensorlose Überprüfung, Honeypot-Honeypot-Feldkennungroboter, IP und Zeitstempelfrequenzgrenze verhindert die Bewässerung, und die Erkennung von Inhalten markiert verdächtige Kommentare und ständig mit Angriffen.

So verwenden Sie PHP in Kombination mit AI, um die Erkennung und Optimierung der Textfehlerkorrektur PHP -Syntax zu erreichen So verwenden Sie PHP in Kombination mit AI, um die Erkennung und Optimierung der Textfehlerkorrektur PHP -Syntax zu erreichen Jul 25, 2025 pm 08:57 PM

Um die Textfehlerkorrektur und die Syntaxoptimierung mit AI zu realisieren, müssen Sie die folgenden Schritte ausführen: 1. Wählen Sie ein geeignetes AI -Modell oder ein geeignetes AI -Modell oder ein geeignetes AI -Modell wie Baidu, Tencent API oder Open Source NLP -Bibliothek aus; 2. Rufen Sie die API über die Curl oder das Guzzle von PHP auf und verarbeiten Sie die Rückgabeergebnisse. 3.. Informationen zur Fehlerkorrektur in der Anwendung anzeigen und ermöglichen den Benutzern, zu wählen, ob sie angenommen werden sollen. 4. Verwenden Sie PHP-L und PHP_CODESNIFFER für die Syntaxerkennung und -codeoptimierung. 5. sammeln Sie kontinuierlich Feedback und aktualisieren Sie das Modell oder die Regeln, um den Effekt zu verbessern. Konzentrieren Sie sich bei der Auswahl von AIAPI auf die Bewertung von Genauigkeit, Reaktionsgeschwindigkeit, Preis und Unterstützung für PHP. Die Codeoptimierung sollte den PSR -Spezifikationen folgen, Cache vernünftigerweise verwenden, zirkuläre Abfragen vermeiden, den Code regelmäßig überprüfen und x verwenden

PHP nennt AI intelligente Sprachassistenten PHP Voice Interaction System Construction PHP nennt AI intelligente Sprachassistenten PHP Voice Interaction System Construction Jul 25, 2025 pm 08:45 PM

Benutzerspracheingabe wird erfasst und über die Mediarecorder-API des Front-End-JavaScript an das PHP-Backend gesendet. 2. PHP speichert das Audio als temporäre Datei und ruft STTAPI (z. B. Google oder Baidu Voiceerkennung) auf, um sie in Text umzuwandeln. 3. PHP sendet den Text an einen KI -Dienst (wie OpenAigpt), um intelligente Antwort zu erhalten. 4. PHP ruft dann TTSAPI (wie Baidu oder Google Voice -Synthese) auf, um die Antwort in eine Sprachdatei umzuwandeln. 5. PHP streams die Sprachdatei zurück zum Spielen, um die Interaktion abzuschließen. Der gesamte Prozess wird von PHP dominiert, um eine nahtlose Verbindung zwischen allen Links zu gewährleisten.

PHP Integrierte KI intelligente Bilderkennung PHP Visuelle Inhalt Automatische Kennzeichnung PHP Integrierte KI intelligente Bilderkennung PHP Visuelle Inhalt Automatische Kennzeichnung Jul 25, 2025 pm 05:42 PM

Die Kernidee der Integration von KI-visuellen Verständnisfunktionen in PHP-Anwendungen besteht darin, die Visual-Service-API von Drittanbietern zu verwenden, die für das Hochladen von Bildern, das Senden von Anforderungen, das Empfangen und Parsen von JSON-Ergebnissen und das Speichern von Tags in die Datenbank verantwortlich ist. 2. Automatisches Bild -Tagging kann die Effizienz erheblich verbessern, die Durchsuchbarkeit der Inhalte verbessern, das Management und die Empfehlung optimieren und visuelle Inhalte von "toten Daten" in "Live -Daten" ändern. 3. Die Auswahl von AI -Diensten erfordert umfassende Urteile, die auf funktionaler Übereinstimmung, Genauigkeit, Kosten, Benutzerfreundlichkeit, regionaler Verzögerung und Dateneinhaltung der Daten basieren, und es wird empfohlen, von allgemeinen Diensten wie Google CloudVision zu beginnen. 4. Zu den gemeinsamen Herausforderungen gehören das Zeitlimit für Netzwerke, wichtige Sicherheit, Fehlerverarbeitung, Begrenzung des Bildformates, Kostenkontrolle, asynchrone Verarbeitungsanforderungen und Probleme der KI -Erkennungsgenauigkeit.

So verwenden Sie PHP, um KI zu kombinieren, um Bild zu generieren. PHP generiert automatisch Kunstwerke So verwenden Sie PHP, um KI zu kombinieren, um Bild zu generieren. PHP generiert automatisch Kunstwerke Jul 25, 2025 pm 07:21 PM

PHP führt nicht direkt die KI-Image-Verarbeitung durch, sondern integriert sich über APIs, da es in der Webentwicklung und nicht in Bezug auf Computerintensive Aufgaben gut ist. Die API -Integration kann die professionelle Arbeitsteilung erreichen, die Kosten senken und die Effizienz verbessern. 2. Integration von Schlüsseltechnologien umfasst die Verwendung von Guzzle oder Curl zum Senden von HTTP-Anforderungen, JSON-Datencodierung und -decodierung, API-Schlüsselsicherheitsauthentifizierung, asynchroner Warteschlangenverarbeitungsaufgaben, robuster Fehlerbehebung und Wiederholungsmechanismus, Bildspeicherung und Anzeige. 3. Die gemeinsamen Herausforderungen sind API -Kosten außer Kontrolle, unkontrollierbare Erzeugungsergebnisse, schlechte Benutzererfahrung, Sicherheitsrisiken und schwieriges Datenmanagement. In den Antwortstrategien werden Benutzerquoten und -darstellungen festgelegt, die Auswahl von ProPT-Anleitungen und mehrfizierende Auswahl, asynchrone Benachrichtigungen und Fortschrittsaufforderungen, wichtige Speicher- und Inhaltsprüfungen sowie Cloud-Speicher vorhanden.

PHP realisiert Rohstoffbestandsverwaltung und Monetarisierung PHP -Inventarsynchronisation und Alarmmechanismus PHP realisiert Rohstoffbestandsverwaltung und Monetarisierung PHP -Inventarsynchronisation und Alarmmechanismus Jul 25, 2025 pm 08:30 PM

PHP sorgt für die Inventarabzugsatomizität durch Datenbanktransaktionen und Forupdate -Reihenschlösser, um eine hohe gleichzeitige Überverlässigkeit zu verhindern. 2. Multi-Plattform-Inventarkonsistenz hängt von zentraler Verwaltung und ereignisgesteuerter Synchronisation ab, die API/Webhook-Benachrichtigungen und Nachrichtenwarteschlangen kombiniert, um eine zuverlässige Datenübertragung sicherzustellen. 3. Der Alarmmechanismus sollte in verschiedenen Szenarien niedrige Lagerbestände, Null/Negativ -Inventar, unerwünschte Verkaufszyklen, Nachschubzyklen und abnormale Schwankungsstrategien festlegen und die Auswahl von Dingtalk, SMS oder E -Mail -Verantwortlichen gemäß der Dringlichkeit auswählen, und die Alarminformationen müssen vollständig und frei sein, um die Anpassung und die Vergewaltigungsreaktion zu erreichen.

So verwenden Sie PHP, um KI-gesteuerte Werbezuschaltung zu entwickeln. So verwenden Sie PHP, um KI-gesteuerte Werbezuschaltung zu entwickeln. Jul 25, 2025 pm 06:12 PM

PHP bietet eine Eingabebasis für KI-Modelle, indem Benutzerdaten (z. B. Browserhistorie, geografischer Standort) und Vorverarbeitung gesammelt werden. 2. Verwenden Sie Curl oder GRPC, um mit KI-Modellen eine Verbindung herzustellen, um die Ergebnisse der Klickrate und der Konversionsrate-Vorhersageergebnisse zu erhalten. 3.. Anpassen dynamisch Werbeanzeigefrequenz, Zielpopulation und andere Strategien, die auf Vorhersagen basieren; 4. Testen Sie verschiedene Werbevarianten über A/B und zeichnen Sie Daten auf und kombinieren Sie die statistische Analyse, um den Effekt zu optimieren. 5. Verwenden Sie PHP, um Verkehrsquellen und Benutzerverhalten zu überwachen und in APIs von Drittanbietern wie Googleads zu integrieren, um eine automatisierte Lieferung und kontinuierliche Feedback-Optimierung zu erzielen, letztendlich CTR und CVR zu verbessern und CPC zu reduzieren, und die vollständige Implementierung der geschlossenen Schleife des AI-gesteuerten Werbesystems vollständig implementieren.

See all articles