이 글에서는 주로 MySQL 연결 풀을 이용한 Node.js의 방법을 소개하고, 구체적인 예시를 바탕으로 mysql 연결 풀을 운영하기 위한 nodejs의 관련 모듈 설치, 연결, 쿼리 및 기타 활용 기술을 분석합니다. 이 기사에서는
Node.js가 MySQL 연결 풀을 사용하는 방법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 자세한 내용은 다음과 같습니다.
Nodejs와 함께 MySQL을 사용하는 방법
Nodejs를 MySQL에 연결하려면 Nodejs의 MysQL 드라이버를 사용할 수 있습니다. 예를 들어 여기서는 "node-mysql"을 사용하여 데이터베이스에 연결합니다. 다음 방법을 사용하여 데이터베이스에 연결합니다.
먼저 nodejs 패키지 관리 도구(npm)를 사용하여 mysql 드라이버를 설치해야 합니다. 명령줄은 다음과 같습니다.
npm install musql
이제 js 파일에서 mysql을 사용하려면 파일에 다음 코드를 추가하세요.
var mysql = require('mysql');
다음으로 이 모듈을 사용하여 MySQL 데이터베이스에 연결할 수 있습니다. 물론, 데이터베이스에 연결하려면 MySQL Server의 호스트 이름, 사용자 이름 및 비밀번호를 지정해야 합니다. 데이터베이스 시간대, 소켓 경로, 로컬 주소 등 설정할 수 있는 다른 옵션이 많이 있습니다.
var connection = mysql.createConnection({ host : "hostName", user : "username", password: "password" });
그러면 아래 코드가 새로운 연결을 설정합니다.
connection.connect();
이 연결 개체를 사용하면 아래와 같이 데이터베이스에 쿼리할 수 있습니다. SQL 삽입을 방지하려면 connection.escape()
메서드를 사용할 수 있습니다. connection.escape()
方法防止sql注入。
connection.query("use database1"); var strQuery = "select * from table1"; connection.query( strQuery, function(err, rows){ if(err) { throw err; }else{ console.log( rows ); } });
最后,我们可以用两种方法关闭连接。用connection.end
或者connection.destroy
。
下面的表达式会确保所有队列中的查询在数据库连接关闭前都会被执行。请注意,这里有一个回调函数。
connection.end(function(err){ // Do something after the connection is gracefully terminated. });
下面的表达式会立即关闭数据库连接。并且没有回调函数或者触发任何事件。
connection.destroy( );
Nodejs使用MysQL的连接池
使用连接池可以帮助我们更好的管理数据库连接。数据库连接池可以限制连接的最大数量,复用已有的连接等。
首先,我们需要创建一个连接池:
var mysql = require('mysql'); var pool = mysql.createPool({ host : "hostName", user : "username", password: "password" });
其次,我们可以从创建的连接池中获取到一个我们需要的连接:
pool.getConnection(function(err, connection){ });
使用回调函数的参数connection来查询数据库。最后使用connection.realease()
pool.getConnection(function(err, connection){ connection.query( "select * from table1", function(err, rows){ if(err) { throw err; }else{ console.log( rows ); } }); connection.release(); });
connection.end
또는 connection.destroy
를 사용하세요. 다음 표현식은 데이터베이스 연결이 닫히기 전에 대기열의 모든 쿼리가 실행되도록 보장합니다. 여기에 콜백 함수가 있다는 점에 유의하세요.
var connection = mysql.createConnection( { multipleStatements: true } );
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 } });
연결 풀을 사용하면 데이터베이스 연결을 더 잘 관리하는 데 도움이 될 수 있습니다. 데이터베이스 연결 풀은 최대 연결 수를 제한하고 기존 연결을 재사용하는 등의 작업을 수행할 수 있습니다.
먼저 연결 풀을 생성해야 합니다.npm -install -g node-mysql
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;
connection.realease()
메서드를 사용하여 데이터베이스 연결을 해제합니다. var query=require("./lib/mysql.js"); query("select 1 from 1",function(err,vals,fields){ //do something });
여러 쿼리문 실행
보안상의 이유로 다중 쿼리문 실행은 기본적으로 허용되지 않습니다. 다중 쿼리문 기능을 사용하려면 데이터베이스 연결 생성 시 이 기능을 켜야 합니다.rrreee
이 기능을 활성화한 후에는 다음 예시와 같이 여러 쿼리문을 동시에 사용할 수 있습니다.rrreee
Node.js mysql 연결 풀 모듈1 noderrreee
2의 mysql 모듈을 설치해 보겠습니다. mysql.js라고 부르면 내용은 다음과 같습니다.🎜rrreee🎜 3. js 클래스에서 다음을 사용하세요🎜rrreee🎜위 내용은 제가 모든 사람을 위해 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다. 🎜🎜관련 기사: 🎜🎜🎜vue2.0의 dev-server.js에는 구성 방법이 없습니다🎜🎜🎜🎜Vue.set을 사용하여 Vue에서 객체 속성 메서드를 동적으로 추가🎜🎜🎜🎜vue 속성에서 동적으로 바인딩하는 방법 양식 요소🎜🎜위 내용은 Node.js와 함께 MySQL 연결 풀 사용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!