Heim Web-Frontend js-Tutorial Verwendung des MySQL-Verbindungspools mit Node.js

Verwendung des MySQL-Verbindungspools mit Node.js

Jun 06, 2018 am 11:20 AM
mysql连接池 node.js

Dieser Artikel stellt hauptsächlich die Methode vor, mit der Node.js den MySQL-Verbindungspool verwendet, und analysiert die zugehörigen Modulinstallations-, Verbindungs-, Abfrage- und anderen Verwendungsfähigkeiten von NodeJS, die den MySQL-Verbindungspool betreiben, anhand spezifischer Beispiele

Das Beispiel in diesem Artikel beschreibt, wie Node.js den MySQL-Verbindungspool verwendet. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

So verwenden Sie MySQL in Nodejs

Um Nodejs mit MySQL zu verbinden, Sie können den MysQL-Treiber von Nodejs verwenden. Zum Beispiel verwenden wir hier „node-mysql“, um eine Verbindung zur Datenbank herzustellen. Wir verwenden die folgende Methode, um eine Verbindung zur Datenbank herzustellen:

Zuerst müssen wir das Paketverwaltungstool „nodejs“ (npm) verwenden, um den MySQL-Treiber zu installieren. Die Befehlszeile lautet wie folgt:

npm install musql
Nach dem Login kopieren

Um nun MySQL in einer JS-Datei zu verwenden, fügen Sie den folgenden Code zu Ihrer Datei hinzu:

var mysql = require('mysql');
Nach dem Login kopieren

Als nächstes können wir dieses Modul verwenden, um eine Verbindung zu MySQL herzustellen Datenbank. Um eine Verbindung zur Datenbank herzustellen, müssen Sie natürlich den Hostnamen, den Benutzernamen und das Passwort des MySQL-Servers angeben. Es können viele weitere Optionen festgelegt werden, z. B. die Zeitzone der Datenbank, socketPath und die lokale Adresse.

var connection = mysql.createConnection({
  host : "hostName",
  user : "username",
  password: "password"
});
Nach dem Login kopieren

Dann stellt der folgende Code eine neue Verbindung für Sie her.

connection.connect();
Nach dem Login kopieren

Mit diesem Verbindungsobjekt können wir die Datenbank wie folgt abfragen. Wir können die Methode connection.escape() verwenden, um die SQL-Injektion zu verhindern.

connection.query("use database1");
 var strQuery = "select * from table1";
 connection.query( strQuery, function(err, rows){
  if(err) {
   throw err;
  }else{
   console.log( rows );
  }
});
Nach dem Login kopieren

Schließlich können wir die Verbindung auf zwei Arten schließen. Verwenden Sie connection.end oder connection.destroy.

Der folgende Ausdruck stellt sicher, dass alle Abfragen in der Warteschlange ausgeführt werden, bevor die Datenbankverbindung geschlossen wird. Bitte beachten Sie, dass es hier eine Rückruffunktion gibt.

connection.end(function(err){
// Do something after the connection is gracefully terminated.
});
Nach dem Login kopieren

Der folgende Ausdruck schließt sofort die Datenbankverbindung. Und es werden keine Rückruffunktionen oder Ereignisse ausgelöst.

connection.destroy( );
Nach dem Login kopieren

Nodejs verwendet den Verbindungspool von MysQL

Die Verwendung eines Verbindungspools kann uns helfen, Datenbankverbindungen besser zu verwalten. Der Datenbankverbindungspool kann die maximale Anzahl von Verbindungen begrenzen, vorhandene Verbindungen wiederverwenden usw.

Zuerst müssen wir einen Verbindungspool erstellen:

var mysql = require('mysql');
var pool = mysql.createPool({
 host : "hostName",
 user : "username",
 password: "password"
});
Nach dem Login kopieren

Zweitens können wir die benötigte Verbindung aus dem erstellten Verbindungspool abrufen:

pool.getConnection(function(err, connection){
});
Nach dem Login kopieren

Verwenden Sie den Callback-Funktionsparameter Verbindung zur Abfrage der Datenbank. Verwenden Sie abschließend die Methode connection.realease(), um die Datenbankverbindung freizugeben.

pool.getConnection(function(err, connection){
 connection.query( "select * from table1", function(err, rows){
  if(err) {
   throw err;
  }else{
   console.log( rows );
  }
 });
 connection.release();
});
Nach dem Login kopieren

Mehrere Abfrageanweisungen ausführen

Aus Sicherheitsgründen ist die Ausführung mehrerer Abfrageanweisungen standardmäßig nicht zulässig. Um die Funktion mehrerer Abfrageanweisungen zu verwenden, müssen Sie diese Funktion beim Erstellen einer Datenbankverbindung aktivieren:

var connection = mysql.createConnection( { multipleStatements: true } );
Nach dem Login kopieren

Nachdem diese Funktion aktiviert ist, können Sie mehrere Abfrageanweisungen gleichzeitig verwenden, wie im folgenden Beispiel :

connection.query('select column1; select column2; select column3;', function(err, result){
 if(err){
  throw err;
 }else{
  console.log(result[0]);  // Column1 as a result
  console.log(result[1]);  // Column2 as a result
  console.log(result[2]);  // Column3 as a result
 }
});
Nach dem Login kopieren

Die Verwendung des MySQL-Verbindungspools in node.js

Wenn Sie nicht möchten, dass das Programm hängen bleibt oder auch wartet lang beim Abfragen von Daten, im Allgemeinen Es wird nicht empfohlen, diesen Link für alle Abfragen zu verwenden, nachdem eine Verbindung im Knoten geöffnet und nicht geschlossen wurde, da Sie wissen, warum, nachdem Sie es ausprobiert haben

Node.js MySQL-Verbindungspoolmodul

1. Das MySQL-Modul des Installationsknotens

npm -install -g node-mysql
Nach dem Login kopieren

2. Erstellen Sie eine Klassenbibliothek, nennen wir sie mysql.js, und der Inhalt lautet wie folgt:

var mysql=require("mysql");
var pool = mysql.createPool({
 host: 'localhost',
 user: 'user',
 password: 'password',
 database: 'database',
 port: port
});
var query=function(sql,callback){
 pool.getConnection(function(err,conn){
  if(err){
   callback(err,null,null);
  }else{
   conn.query(sql,function(qerr,vals,fields){
    //释放连接
    conn.release();
    //事件驱动回调
    callback(qerr,vals,fields);
   });
  }
 });
};
module.exports=query;
Nach dem Login kopieren

3 Folgendes in der js-Klasse:

var query=require("./lib/mysql.js");
query("select 1 from 1",function(err,vals,fields){
 //do something
});
Nach dem Login kopieren

Das Obige habe ich für alle zusammengestellt. Ich hoffe, dass es in Zukunft für alle hilfreich sein wird.

Verwandte Artikel:

Konfigurationsmethode ohne dev-server.js in vue2.0

Verwenden von Vue in Vue set method to Objektattribute dynamisch hinzufügen

So binden Sie Attribute von Formularelementen in Vue dynamisch

Das obige ist der detaillierte Inhalt vonVerwendung des MySQL-Verbindungspools mit Node.js. 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

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.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

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)

Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Mar 29, 2023 pm 06:02 PM

Dieser Artikel vermittelt Ihnen ein detailliertes Verständnis des Speichers und Garbage Collectors (GC) der NodeJS V8-Engine. Ich hoffe, er wird Ihnen hilfreich sein!

Ein Artikel über Speichersteuerung in Node Ein Artikel über Speichersteuerung in Node Apr 26, 2023 pm 05:37 PM

Der nicht blockierende und ereignisgesteuerte Knotendienst hat den Vorteil eines geringen Speicherverbrauchs und eignet sich sehr gut für die Verarbeitung massiver Netzwerkanforderungen. Unter der Voraussetzung massiver Anfragen müssen Probleme im Zusammenhang mit der „Speicherkontrolle“ berücksichtigt werden. 1. Der Garbage-Collection-Mechanismus und die Speicherbeschränkungen von V8 Js wird von der Garbage-Collection-Maschine gesteuert

Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Dec 13, 2022 pm 08:00 PM

Die Auswahl eines Docker-Images für Node mag trivial erscheinen, aber die Größe und potenziellen Schwachstellen des Images können erhebliche Auswirkungen auf Ihren CI/CD-Prozess und Ihre Sicherheit haben. Wie wählen wir also das beste Node.js-Docker-Image aus?

Lassen Sie uns ausführlich über das File-Modul in Node sprechen Lassen Sie uns ausführlich über das File-Modul in Node sprechen Apr 24, 2023 pm 05:49 PM

Das Dateimodul ist eine Kapselung der zugrunde liegenden Dateioperationen, wie z. B. Lesen/Schreiben/Öffnen/Schließen/Löschen von Dateien, Hinzufügen usw. Das größte Merkmal des Dateimoduls besteht darin, dass alle Methoden zwei Versionen von **synchronem** und **bereitstellen. asynchron**, mit Methoden mit dem Suffix sync sind alle Synchronisationsmethoden, und diejenigen ohne sind alle heterogene Methoden.

Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Nov 29, 2022 pm 08:44 PM

Wie führt Node.js GC (Garbage Collection) durch? Der folgende Artikel führt Sie durch.

Lassen Sie uns über die Ereignisschleife in Node sprechen Lassen Sie uns über die Ereignisschleife in Node sprechen Apr 11, 2023 pm 07:08 PM

Die Ereignisschleife ist ein grundlegender Bestandteil von Node.js und ermöglicht die asynchrone Programmierung, indem sie sicherstellt, dass der Hauptthread nicht blockiert wird. Das Verständnis der Ereignisschleife ist für die Erstellung effizienter Anwendungen von entscheidender Bedeutung. Der folgende Artikel wird Ihnen ein detailliertes Verständnis der Ereignisschleife in Node vermitteln. Ich hoffe, er wird Ihnen hilfreich sein!

Erfahren Sie mehr über Puffer in Node Erfahren Sie mehr über Puffer in Node Apr 25, 2023 pm 07:49 PM

Zu Beginn lief JS nur auf der Browserseite. Es war einfach, Unicode-codierte Zeichenfolgen zu verarbeiten, aber es war schwierig, binäre und nicht Unicode-codierte Zeichenfolgen zu verarbeiten. Und Binär ist das Datenformat der niedrigsten Ebene des Computer-, Video-/Audio-/Programm-/Netzwerkpakets

Lassen Sie uns darüber sprechen, wie Sie mit pkg Node.js-Projekte in ausführbare Dateien packen. Lassen Sie uns darüber sprechen, wie Sie mit pkg Node.js-Projekte in ausführbare Dateien packen. Dec 02, 2022 pm 09:06 PM

Wie packe ich die ausführbare Datei von nodejs mit pkg? Im folgenden Artikel erfahren Sie, wie Sie mit pkg ein Node-Projekt in eine ausführbare Datei packen. Ich hoffe, dass er Ihnen weiterhilft!

See all articles