Riucc's Storage
RSS
태그
관리
쓰기
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
Riucc's Storage

[NodeJS] - MySQL 연동하기(Connection Pool), insert문

NodeJS|2018. 12. 3. 15:45
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

○ NodeJS - MySQL 연동하기(Connection Pool), insert문

 

※ Connection Pool 설정은 http://riucc.tistory.com/533 참조


// app.js


// 'pool.getConnection() -> connection.query() -> connection.release()' 코드 흐름을 따름


router.route('/process/notice_write_action').post(function(req, res) {

    // post로 전송한 데이터 받아옴(name = notice_title, name = notice_desc)

    var title = req.body.notice_title;   

    var desc = req.body.notice_desc;


    // 커넥션 풀에서 연결 객체를 가져옴

    pool.getConnection(function(err, conn) {

        if (err) {

            if (conn) {

                conn.release();  // 반드시 해제해야 함

             } 

            callback(err, null);

            return;

        }   

        console.log('데이터베이스 연결 스레드 아이디 : ' + conn.threadId);


        // 현재날짜 구하기

        var dt = new Date();

        var year = dt.getFullYear();

        var month = dt.getMonth() + 1;

        var day = dt.getDate();

        var hour = dt.getHours();

        var minute = dt.getMinutes();

        var second = dt.getSeconds();

        var current_date = (year + '-' + month + '-' + day + ' ' + hour + ':' 

        + minute + ':' + second);


       // 데이터들을 객체로 만듬(db속성:넣을 값)

        var data = {noticeTitle:title, noticeDesc:desc, noticeDate:current_date};

   

        // SQL 문을 실행함(set 으로 객체 만든거 가져다 사용)

        conn.query('insert into notice set ?', data, function(err, result) {

            conn.release();  // 반드시 해제해야 함(해제안할 시 DB연결 수가 계속 늘어남!!!)

                                  //  connectionLimit 값이 작을 경우 초과해서 서버 터짐  

            console.log(result);

            if(result) {

                console.log('정상적으로 공지사항 DB에 입력 완료');

                res.redirect('/process/notice');  

            } else {

                console.log('공지사항 DB에 입력 실패');

            }

        });

    });

});


// notice_write.ejs


<!-- 공지 제목 : notice_title, 공지 내용 : notice_desc -->
<div class="container">
<h3 style="margin-bottom: 30px; text-align: center;">공지사항 작성</h3>
<form method="post" action="/process/notice_write_action">
<div class="form-group">
<!-- Name field -->
<label class="control-label" for="name">공지 제목</label>
<input class="form-control" id="notice_title" name="notice_title"
type="text" />
</div>

<div class="form-group">
<!-- Message field -->
<label class="control-label" for="message">공지 내용</label>
<textarea class="form-control" cols="40" id="notice_desc" name="notice_desc"
rows="10"></textarea>
</div>

<div class="form-group">
<button class="btn btn-primary" name="submit" type="submit"
style="float: right;">작성</button>
</div>
</form>
</div>


저작자표시 (새창열림)

'NodeJS' 카테고리의 다른 글

[NodeJS] - MySQL 연동해서 데이터 출력 시 줄바꿈 방법  (0) 2018.12.04
[NodeJS] - MySQL 연동하기(Connection Pool), delete문  (0) 2018.12.03
[NodeJS] - MySQL 연동하기(Connection Pool), select문  (0) 2018.12.03
[NodeJS] - html, ejs 파일 읽기 위한 ejs 미들웨어  (0) 2018.11.10
[NodeJS] - express에서 정적인 파일을 제공(이미지, css, js 등)  (0) 2018.11.10

댓글()
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
최근 등록 현황
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
달력
지난달
2025.10
다음달
일월화수목금토
1234
567891011
12131415161718
19202122232425
262728293031
태그 구름
  • 정보처리산업기사 16년 필기
  • 커널 모듈 프로그래밍
  • 정규화
  • 자료구조
  • jsp
  • 정보처리산업기사 정리
  • 정보처리산업기사 총정리
  • 안드로이드 intent
  • nodejs express
  • 정보처리산업기사 필기 정리
  • 정보처리산업기사 요약
  • 안드로이드 카카오 로그인
  • 정보처리산업기사 15년 필기
  • 정보처리산업기사 필기
  • 카카오 로그인 연동
  • 정보처리산업기사 15년
  • 데이터베이스
  • 리눅스
  • 소켓 프로그래밍
  • 이클립스 mysql 연동
  • 정규형
  • 소켓
  • HTML
  • 이클립스 디비 연동
  • 안드로이드 카카오 로그인 연동
  • nodejs MySQL 연동하기(Connection Pool)
  • 정보처리산업기사 16년
  • 카카오 로그인
  • 정보처리기사 실기 정리
  • 안드로이드
카운터
전체 방문자
오늘
어제
Skin by M1REACT. Designed by M1STORY.TISTORY.COM. Valid XHTML 1.0 and CSS 3. Copyright ⓒ Riucc's Storage. All rights reserved.

티스토리툴바