Node.js와 함께 MySQL 연결 풀 사용
이 글에서는 주로 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 기사는 NodeJS V8 엔진의 메모리 및 가비지 수집기(GC)에 대한 심층적인 이해를 제공할 것입니다. 도움이 되기를 바랍니다.

Non-Blocking, Event-Driven 기반으로 구축된 Node 서비스는 메모리 소모가 적다는 장점이 있으며, 대규모 네트워크 요청을 처리하는데 매우 적합합니다. 대규모 요청을 전제로 '메모리 제어'와 관련된 문제를 고려해야 합니다. 1. V8의 가비지 수집 메커니즘과 메모리 제한 Js는 가비지 수집 기계에 의해 제어됩니다.

Node용 Docker 이미지를 선택하는 것은 사소한 문제처럼 보일 수 있지만 이미지의 크기와 잠재적인 취약점은 CI/CD 프로세스와 보안에 상당한 영향을 미칠 수 있습니다. 그렇다면 최고의 Node.js Docker 이미지를 어떻게 선택합니까?

파일 모듈은 파일 읽기/쓰기/열기/닫기/삭제 추가 등과 같은 기본 파일 작업을 캡슐화한 것입니다. 파일 모듈의 가장 큰 특징은 모든 메소드가 **동기** 및 ** 두 가지 버전을 제공한다는 것입니다. 비동기**, sync 접미사가 있는 메서드는 모두 동기화 메서드이고, 없는 메서드는 모두 이기종 메서드입니다.

이벤트 루프는 Node.js의 기본 부분이며 메인 스레드가 차단되지 않도록 하여 비동기 프로그래밍을 가능하게 합니다. 이벤트 루프를 이해하는 것은 효율적인 애플리케이션을 구축하는 데 중요합니다. 다음 기사는 Node.js의 이벤트 루프에 대한 심층적인 이해를 제공할 것입니다. 도움이 되기를 바랍니다!

nodejs 실행 파일을 pkg로 패키징하는 방법은 무엇입니까? 다음 기사에서는 pkg를 사용하여 Node 프로젝트를 실행 파일로 패키징하는 방법을 소개합니다. 도움이 되기를 바랍니다.

Node.js는 GC(가비지 수집)를 어떻게 수행하나요? 다음 기사에서는 이에 대해 설명합니다.

초기에 JS는 브라우저 측에서만 실행되었습니다. 유니코드로 인코딩된 문자열은 처리하기 쉬웠지만 바이너리 및 유니코드가 아닌 인코딩된 문자열을 처리하는 것은 어려웠습니다. 그리고 바이너리는 컴퓨터의 가장 낮은 데이터 형식인 비디오/오디오/프로그램/네트워크 패키지입니다.
