Sie können das npm-Tool verwenden, um das MySQL-Paket in nodejs zu installieren. Die spezifische Installationsmethode: 1. Öffnen Sie das Terminal und geben Sie das angegebene Projektverzeichnis ein. 2. Führen Sie den Befehl „npm install mysql --save“ aus Download und Installation abschließen.
Die Betriebsumgebung dieses Tutorials: Windows7-System, NodeJS-Version 14.15.4, DELL G3-Computer.
Sie müssen zuerst nodejs und npm installieren.
Ein einfaches kleines Beispiel geschrieben. Das gesamte kleine Beispiel verwendet das Express-Framework. Die Express- und EJS-Vorlagen wurden in node_modules heruntergeladen. Werfen wir zunächst einen Blick auf das Verzeichnis:
server.js =》 node.js Server-Startdatei
db.js =》 Datenbankbetriebsdatei
views =》 Speichern Sie Vorlagendateien, in denen sich alle Seiten befinden gespeichert
public =》 Ein Ort, an dem alle statischen Ressourcen gespeichert werden, wie z. B. CSS-JS-Bilder und dergleichen.
So stellen Sie eine Verbindung zu MySQL her:
Der erste Schritt besteht darin, ein npm-Paket namens MySQL zu installieren Offiziell bereitgestellt. Natürlich gibt es auch andere npm-Pakete. Hier verwenden wir nur das MySQL-Paket. Die Installationsmethode ist sehr einfach: Geben Sie den Befehl ein npm install mysql --save
und warten Sie, bis der Download abgeschlossen ist
Wenn Sie dies sehen, ist die Installation erfolgreich.
Dann öffnen wir die Datei db.js und schreiben einige Codes, die für Datenbankoperationen erforderlich sind:
Der Code ist sehr klein und die Bedeutung ist offensichtlich. Der erste Schritt besteht darin, das MySQL-Paket einzuführen. und dann erstellen wir ein leeres Objekt und weisen ihm eine Methode namens query zu. Diese Methode akzeptiert zwei Parameter. Der erste Parameter ist die SQL-Anweisung, wenn Sie die Daten abfragen, und der zweite Parameter ist die Rückruffunktion, um die Abfrageergebnisse zu erhalten.
Wenn man sich die Funktion ansieht, wird der erste Codeblock verwendet, um die Konfiguration für den Betrieb von MySQL festzulegen:
host stellt die Adresse der MySQL-Installation dar, da ich eine lokale Datenbank habe und daher localhost direkt verwende
Benutzer steht für den Benutzernamen von MySQL.
Passwort steht für das Passwort von MySQL.
Datenbank steht für den Namen der spezifischen Bibliothek, die Sie betreiben möchten.
Port steht für den Port, der leer gelassen werden kann. Der Standardwert ist 3306
mysql Der Rückgabewert von createConnection, Verbindung, ist ein spezifisches Objekt für unsere nächste Operation von MySQL.
Rufen Sie die Verbindungsmethode auf, um festzustellen, ob die Verbindung erfolgreich ist. Wenn die Verbindung fehlschlägt, drucken Sie die Fehlermeldung aus und beenden Sie die Ausführung.
Rufen Sie die Abfragemethode der Verbindung auf, um SQL-Anweisungen direkt an die Datenbank zu senden, und verwenden Sie die Rückruffunktion, um das Ergebnis zurückzugeben. Der erste Parameter ist das Fehlerobjekt Wenn der Vorgang fehlschlägt, wird die Fehlermeldung abgebrochen. Der zweite Parameter ist das spezifische zurückgegebene Ergebnis. Unter normalen Umständen ist es ein Array, das viel JSON enthält der einzelnen Daten, z. B. zu welcher Bibliothek die aktuellen Daten gehören, zu welcher Tabelle usw. Der zweite Parameter, den wir am häufigsten verwenden, ist natürlich der zweite Parameter. Wenn der Datenbankvorgang abgeschlossen ist, weiß ich nicht, ob jemand auf das Problem gestoßen ist, dass die Verbindung zum ersten Mal verloren geht Die Verbindung zur Datenbank ist normal. Wenn ich die Homepage zum zweiten Mal besuche, kann keine Verbindung zur Datenbank hergestellt werden und es wird eine Fehlermeldung angezeigt, dass die Verbindung unterbrochen wurde. Der Grund dafür ist, dass wir die Datenbankverbindung nach jedem Datenbankvorgang schließen. Wenn wir erneut auf die Datenbank zugreifen, können wir die Verbindung nicht finden, aber die Verbindung muss geschlossen werden Wird bei jedem Besuch der Homepage aufgerufen? Wird nicht jedes Mal eine neue Verbindung generiert? Ja, es ist nur so, dass der Code, der die Verbindung zu Beginn generiert hat, nicht in der Funktion db.query, sondern außerhalb platziert wurde, wie unten gezeigt:
Dadurch wird die Verbindung nur einmal erstellt. Nach dem Schließen wird das zweite Interview nicht mehr verbunden. Nachdem Sie es in die Funktion eingefügt haben, verwenden Sie Exporte, um die Schnittstelle der Außenwelt zugänglich zu machen. Jedes Mal, wenn Sie die Homepage besuchen, müssen Sie erneut eine Verbindung herstellen und erhalten jedes Mal eine neue Verbindung, sodass der Zugriff problemlos möglich ist. Tatsächlich kann der Verbindungspool direkt im Projekt verwendet werden. Hat viel Ärger gespart.
Das zweite Problem besteht darin, dass wir db.js in server.js eingeführt haben
Möglicherweise haben Sie zu diesem Zeitpunkt gesehen, dass mysql.query zwei Parameter hat, der erste ist SQL und der zweite ist die Rückruffunktion Die Rückruffunktion verfügt über einen Ergebnisparameter, der tatsächlich das Ergebnis der Datenbankabfrage ist. Einige Leute fragen sich vielleicht, warum nicht einfach return in db.js verwendet wird, um die Abfrageergebnisse zurückzugeben und einen Rückruf durchzuführen!
Tatsächlich treten hier einige Probleme auf, die durch die Asynchronität von node.js verursacht werden. Wenn wir den Code in server.js in das Bild unten ändern, sehen wir, dass die Abfragemethode des MySQL-Pakets ist eine asynchrone Operation. Dies führt dazu, dass die folgende res.render()-Methode nicht auf die Abfrage des Ergebnisses wartet, bevor sie ausgeführt wird. Oftmals wird die Seite gerendert, bevor das Ergebnis ausgegeben wird, die Daten werden jedoch nicht abgerufen Fehler wird gemeldet. Daher mussten wir eine Rückruffunktion übergeben. Nachdem die MySQL-Abfragemethode beendet war, wurden die Ergebnisse über Parameter an die Rückruffunktion übergeben, die wir selbst geschrieben hatten, damit wir die Ergebnisse in der Rückruffunktion erhalten konnten. Führen Sie dann das Rendern durch. Um dieses Problem zu lösen, können Sie natürlich auch das asynchrone Paket eines Drittanbieters einführen, um das asynchrone Problem zu lösen.
【Verwandte Empfehlung: „Wie installiere ich NodeJS in einer Windows-Umgebung?“
》】Das obige ist der detaillierte Inhalt vonSo installieren Sie das MySQL-Paket in NodeJS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!