2026, 새로운 도약을 시작합니다.

mysql 연결 방법 2가지

· 11년 전 · 2609 · 2

2014년 현재 가장 많이 쓰이는 mysql 연결 방법은 2가지 정도 있는 듯 합니다.

일단 mysql을 사용하려면 mysql 모듈을 설치하셔야 합니다.  

npm install mysql  또는 package.json 에 추가하여 npm install

단일 커넥션으로 연결하기

예)

var mysql = require('mysql');   // mysql 모듈 불러오고 

var connection = mysql.createConnection({   // 연결 객체 생성 

host : '호스트 이름',

user: '사용자',

password : '비밀번호' 

});

connection.connect();  // mysql 연결 

connection.query("sql 쿼리", function(err, results, fields) {

})   // query 실행 

connection.end();  // mysql 연결 종료

connection.query()의 용법을 살펴 보면

1. connection.query("sql 쿼리")  -- 경우에 따라 콜백 함수가 생략 될 수 있다. sql 쿼리만 입력하는 경우는 STATEMENT 타입이며, 입력 값이 있을 경우 connection.escape()를 사용하여 반드시 escape 하여야 SQL Injection을 예방할 수 있다.

2. connection.query("sql 쿼리", "입력 값") - preparedStatement로 사용될 때 이다. 콜백 함수가 들어 갈 수 도 있으나, 경우에 따라 생략 될 수 도 있다.  

  예) connection.query("INSERT INTO member ( username ) VALUES (?)", "bluebird")

3. 콜백 함수와 함께 사용 - 콜백 함수와 함께 사용하는 경우는 보통 데이터를 추출하는 경우이다. argument는 보통 2, 3개가 사용될 수 있다.  

   예) connection.query("SELECT * FROM member WHERE username=?", username, function(err, results, fields) {

if (err) throw err;

else {

console.log(results) // SQL 쿼리를 통해 추출된 데이터 배열, 배열 안에는 JSON의 형태로 필드는 키, 데이터는 값의 형태로 담겨 있다.  

console.log(fields) 추출된 데이터의 필드명 및 기타 데이터가 담겨 있다. 

}); 

커넥션 풀사용하는 연결

예)

var mysql = require('mysql');

var pool = mysql.createPool({   // 커넥션 풀 형성

host : "호스트명",

user : "사용자",

password : "비밀번호"

});

pool.getConnection(function(err, connection) {  // 연결

if ( err ) throw err;

else {

connection.query("SELECT * FROM member", function(err, results) {

if (err) throw err;

else console.log(results);

})

connection.release() // 연결 해제

}

});

커넥션풀의 경우 연결을 여러개 만들어 놓고 사용하기 때문에 많은 사용자가 접속하는 어플리케이션(웹 또는 기타)일 때 단일 연결일때 보다 속도 향상을 가져온다고 한다.

createPool을 사용하여 커넥션 풀을 생성하며

필요할 때 마다 연결을 생성하고 그 안에서 쿼리를 하는 형태이다.

connection.query는 단일 연결에서 사용한 것과 사용방법이 동일 하므로 설명을 생략 한다.

다른 점은 커넥션이 종료 되는 것이 아기 때문에 쿼리가 완료되면 end가 아니라 release(connection.release())를 한다.

|

댓글 2개

감사합니다.~
저는 nodejs에서 mysql을 쓰기가 조금 꺼려지더라구요.

좋아요+스크랩 해갑니다.~
좋은정보 감사합니다~

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

프로그램

+
번호 제목 글쓴이 날짜 조회
8230 9년 전 조회 20
8229 9년 전 조회 25
8228 9년 전 조회 62
8227 9년 전 조회 72
8226 9년 전 조회 117
8225 9년 전 조회 100
8224 9년 전 조회 92
8223 9년 전 조회 54
8222 9년 전 조회 126
8221 9년 전 조회 38
8220 9년 전 조회 35
8219 9년 전 조회 38
8218 9년 전 조회 73
8217 9년 전 조회 51
8216 9년 전 조회 101
8215 9년 전 조회 56
8214 9년 전 조회 175
8213 9년 전 조회 116
8212 9년 전 조회 22
8211 9년 전 조회 191
8210 9년 전 조회 181
8209 9년 전 조회 281
8208 9년 전 조회 154
8207 9년 전 조회 171
8206 9년 전 조회 127
8205 9년 전 조회 119
8204 9년 전 조회 75
8203 9년 전 조회 168
8202 9년 전 조회 97
8201 9년 전 조회 137
8200 9년 전 조회 94
8199 9년 전 조회 149
8198 9년 전 조회 123
8197 9년 전 조회 103
8196 9년 전 조회 481
8195 9년 전 조회 103
8194 9년 전 조회 239
8193 9년 전 조회 108
8192 9년 전 조회 134
8191 9년 전 조회 87
8190 9년 전 조회 83
8189 9년 전 조회 141
8188 9년 전 조회 71
8187 9년 전 조회 91
8186 9년 전 조회 101
8185 9년 전 조회 260
8184 9년 전 조회 57
8183 9년 전 조회 286
8182 9년 전 조회 117
8181 9년 전 조회 84
8180 9년 전 조회 647
8179 9년 전 조회 443
8178 9년 전 조회 248
8177 9년 전 조회 253
8176 9년 전 조회 298
8175 9년 전 조회 172
8174 9년 전 조회 178
8173 9년 전 조회 295
8172 9년 전 조회 138
8171 9년 전 조회 137
8170 9년 전 조회 245
8169 9년 전 조회 215
8168 9년 전 조회 263
8167 9년 전 조회 275
8166 9년 전 조회 188
8165 9년 전 조회 129
8164 9년 전 조회 247
8163 9년 전 조회 235
8162 9년 전 조회 244
8161 9년 전 조회 233
8160 9년 전 조회 436
8159 9년 전 조회 341
8158 9년 전 조회 163
8157 9년 전 조회 307
8156 9년 전 조회 219
8155 9년 전 조회 201
8154 9년 전 조회 541
8153 9년 전 조회 176
8152 9년 전 조회 346
8151 9년 전 조회 358
8150 9년 전 조회 445
8149 9년 전 조회 283
8148 9년 전 조회 112
8147 9년 전 조회 332
8146 9년 전 조회 386
8145 9년 전 조회 306
8144 9년 전 조회 272
8143 9년 전 조회 125
8142 9년 전 조회 377
8141 9년 전 조회 328
8140 9년 전 조회 869
8139 9년 전 조회 193
8138 9년 전 조회 339
8137 9년 전 조회 316
8136 9년 전 조회 683
8135 9년 전 조회 721
8134 9년 전 조회 437
8133 9년 전 조회 387
8132 9년 전 조회 401
8131 9년 전 조회 753
🐛 버그신고