한국어

네트워킹

온누리070 플레이스토어 다운로드
    acrobits softphone
     온누리 070 카카오 프러스 친구추가온누리 070 카카오 프러스 친구추가친추
     카카오톡 채팅 상담 카카오톡 채팅 상담카톡
    
     라인상담
     라인으로 공유

     페북공유
    
     PAYPAL
     
     PRICE
     

pixel.gif

    before pay call 0088 from app


http://snix.tistory.com/134

 

 

[09-D16][JDBC] PreparedStatement

[01] PreparedStatement 클래스의 사용

    - 자바에서 보낸 쿼리가 데이터베이스의 캐시 영역에 컴파일되어 저장되어 있음으로
      같은 쿼리를 실행시 빠른 처리속도를 지원합니다.

    - 10000개의 레코드 추가시 Statement 클래스 보다 처리속도 약 13초 빠름.

    - 간결하고 구조적인 쿼리문 작성 가능.

    - 반복해서 같은 쿼리를 보낼 경우 효과가 큼.

    - SQL Injection등의 공격을 피할 수 있는 구조를 가지고 있음.

    - 현재 Oracle만 이 기능을 지원합니다. 따라서 다른 데이터베이스는 내부적으로
       Statement로 변경되어 실행됩니다. (MySQL은 5.0버전부터 지원)

    - INSERT, UPDATE, DELETE SQL 실행
      int cnt = pstmt.executeUpdate();

    - SELECT SQL 실행
      ResultSet rs = pstmt.executeQuery();

    - 콘솔상에서의 실행, JDBC Driver 복사
      H:
      cd H:\dos4\workspace_java\day17\bin
      java -classpath %CLASSPATH%;mysql-connector-java-5.1.12-bin.jar prep.SelectPrepDB

    - 테이블 구조
      . PRIMARY KEY: 컬럼의 값은 중복된 값이 올 수 없습니다.
      . AUTO_INCREMENT: 레코드 추가시 일련번호를 순차적으로 자동으로
                        생성해 줍니다.

DROP TABLE predb;

CREATE TABLE predb(
    no       INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
    language VARCHAR(20) NOT NULL,
    db       VARCHAR(20) NOT NULL,
    os       VARCHAR(30) NOT NULL
);

-- no컬럼은 AUTO_INCREMENT 속성이 선언되어 있음으로 레코드 추가시
-- 컬럼을 명시하지 않아도 자동으로 일련번호가 등록됩니다.
INSERT INTO predb(language, db, os)
VALUES('JSP', 'MySQL, Oracle', '모든 운영체제');

INSERT INTO predb(language, db, os)
VALUES('ASP', 'Access, MS-SQL', 'Windows Server');

INSERT INTO predb(language, db, os)
VALUES('ASP.NET', 'MS-SQL', 'Windows Server');

INSERT INTO predb(language, db, os)
VALUES('PHP', 'MySQL', '모든 운영체제');


SELECT no, language, db, os FROM predb;
+----+----------+----------------+----------------+
| no | language | db             | os             |
+----+----------+----------------+----------------+
|  1 | JSP      | MySQL, Oracle  | 모든 운영체제  |
|  2 | ASP      | Access, MS-SQL | Windows Server |
|  3 | ASP.NET  | MS-SQL         | Windows Server |
|  4 | PHP      | MySQL          | 모든 운영체제  |
+----+----------+----------------+----------------+

 

Eclipse setting
    Project type: Java Project
    Project name: mysql_prep

 


1. INSERT의 이용
   - statementd의 PreparedStatement로의 변경

>>>>> InsertPrepDB.java

package prep;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
//import java.sql.ResultSet;
import java.sql.SQLException;

public class InsertPrepDB {
    public static void main(String args[]) {
        Connection con=null;
        PreparedStatement  pstmt=null;
        //ResultSet rs=null;

        String url = "jdbc:mysql://localhost:3306/javadb?useUnicode=true&characterEncoding=euckr";
        String jdbc = "org.gjt.mm.mysql.Driver";
        String user = "javauser";
        String pass = "1234";
       
        try {
            Class.forName(jdbc);

            //커넥션 연결
            con = DriverManager.getConnection(url, user, pass);

            String sql = " INSERT INTO predb(language, db, os) ";
            sql  = sql + " VALUES(?, ?, ?)";

            //쿼리 지정
            pstmt = con.prepareStatement(sql);

            //(물음표의 순번, 적용할 값)
            pstmt.setString(1, "MVC");
            pstmt.setString(2, "oracle");
            pstmt.setString(3, "모든 운영체제");

            // 레코드 추가후 1을 ret에 저장
            int cnt = pstmt.executeUpdate();

            System.out.println("레코드 " + cnt + "개가 추가 되었습니다.");
           
        } catch(Exception e) {
            System.out.println("SQLException: " + e.getMessage());
        } finally{
            try{
                if ( pstmt != null){ pstmt.close(); }
            }catch(Exception e){}
            try{
                if ( con != null){ con.close(); }
            }catch(Exception e){}
        }
    }

}

 

 

2. SELECT의 이용

>>>>> SelectPrepDB.java

package prep;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

public class SelectPrepDB {
    public static void main(String args[]) {
        Connection con=null;
        PreparedStatement  pstmt=null;
        ResultSet rs=null;

        String url = "jdbc:mysql://localhost:3306/javadb?useUnicode=true&characterEncoding=euckr";
        String jdbc = "org.gjt.mm.mysql.Driver";
        String user = "javauser";
        String pass = "1234";
       
        try {
            Class.forName(jdbc);

            //커넥션 연결
            con = DriverManager.getConnection(url,user, pass);

            String sql = " SELECT no, language, db, os ";
            sql =  sql + " FROM predb ORDER BY no DESC";
            // sql =  sql + " FROM predb WHERE no = ?";

            //쿼리 지정
            pstmt = con.prepareStatement(sql);

            //(물음표의 순번, 적용할 값)
            //문자열 지정 pstmt.setString(....)
            //첫번째 ?표에 값 1을 지정
            //pstmt.setInt(1, 1);

            rs = pstmt.executeQuery();

            // 하나의 레코드 출력
            // if (rs.next() == true){
               
            // 여러개의 레코드 출력   
            while(rs.next()){
                System.out.println("번호: " + rs.getInt("no"));
                System.out.println("언어: " + rs.getString("language"));
                System.out.println("DB  : " + rs.getString("db"));
                System.out.println("OS  : " + rs.getString("os"));
                System.out.println("-------------------------------------");
            }
 
        } catch(Exception e) {
            System.out.println("SQLException: " + e.getMessage());
        } finally{
            try{
                if ( rs != null){ rs.close(); }
            }catch(Exception e){}
            try{
                if ( pstmt != null){ pstmt.close(); }
            }catch(Exception e){}
            try{
                if ( con != null){ con.close(); }
            }catch(Exception e){}
        }
    }
}

 

 

3. UPDATE의 이용

>>>>> UpdatePrepDB.java

package prep;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;

public class UpdatePrepDB {
    public static void main(String args[]) {
        Connection con=null;
        PreparedStatement  pstmt=null;
        //ResultSet rs=null;

        String url = "jdbc:mysql://localhost:3306/javadb?useUnicode=true&characterEncoding=euckr";
        String jdbc = "org.gjt.mm.mysql.Driver";
        String user = "javauser";
        String pass = "1234";
       
        try {
            Class.forName(jdbc);
            con = DriverManager.getConnection(url, user, pass);

            String sql = " UPDATE predb SET language=?, db=?, os=? ";
            sql  = sql + " WHERE no=?";

            //쿼리 지정
            pstmt = con.prepareStatement(sql);

            //(물음표의 순번, 적용할 값)
            pstmt.setString(1, "java");
            pstmt.setString(2, "oracle");
            pstmt.setString(3, "모든 운영체제");
            pstmt.setInt(4, 1);

            // 레코드 추가후 1을 ret에 저장
            int cnt = pstmt.executeUpdate();

            System.out.println("레코드 " + cnt + "개가 수정 되었습니다.");
           
        } catch(Exception e) {
            System.out.println("SQLException: " + e.getMessage());
        } finally{
            try{
                if ( pstmt != null){ pstmt.close(); }
            }catch(Exception e){}
            try{
                if ( con != null){ con.close(); }
            }catch(Exception e){}
        }
    }

}

 

 

4. Delete

>>>>> DeletePrepDB.java

package prep;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
//import java.sql.ResultSet;
import java.sql.SQLException;

public class DeletePrepDB {
    public static void main(String args[]) {
        Connection con = null;
        PreparedStatement pstmt = null;
        //ResultSet rs=null;

        String url = "jdbc:mysql://localhost:3306/javadb?useUnicode=true&characterEncoding=euckr";
        String jdbc = "org.gjt.mm.mysql.Driver";
        String user = "javauser";
        String pass = "1234";
       
        try {
            Class.forName(jdbc);

            //커넥션 연결
            con = DriverManager.getConnection(url, user, pass);

            String sql = " DELETE FROM predb";
            sql  = sql + " WHERE no = ?";

            //쿼리 지정
            pstmt = con.prepareStatement(sql);

            //(물음표의 순번, 적용할 값)
            pstmt.setInt(1, 4);

            int cnt = pstmt.executeUpdate();

            System.out.println("레코드 " + cnt + "개가 삭제 되었습니다.");
           
        } catch(Exception e) {
            System.out.println("SQLException: " + e.getMessage());
        } finally{
            try{
                if ( pstmt != null){ pstmt.close(); }
            }catch(Exception e){}
            try{
                if ( con != null){ con.close(); }
            }catch(Exception e){}
        }
    }

}

 

 

5. JDBC 접속 및 해제 Utility Class의 제작

>>>>> DBConnect.java

package prep;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

public class DBConnect {
    public static Connection getConnection() {
        Connection con = null;

        String url = "jdbc:mysql://localhost:3306/javadb?useUnicode=true&characterEncoding=euckr";
        String jdbc = "org.gjt.mm.mysql.Driver";
        String user = "javauser";
        String pass = "1234";
       
        try {
            Class.forName(jdbc);

            //커넥션 연결
            con = DriverManager.getConnection(url, user, pass);
        } catch(Exception e) {
            System.out.println("SQLException: " + e.getMessage());
        } finally{
        }
       
        return con;
    }
   
    public static void close(Connection con, PreparedStatement pstmt){
        try{
            if ( pstmt != null){ pstmt.close(); }
        }catch(Exception e){}
       
        try{
            if ( con != null){ con.close(); }
        }catch(Exception e){}       
    }
   
    public static void close(Connection con, PreparedStatement pstmt, ResultSet rs){
        try{
            if ( rs != null){ rs.close(); }
        }catch(Exception e){}
       
        try{
            if ( pstmt != null){ pstmt.close(); }
        }catch(Exception e){}
       
        try{
            if ( con != null){ con.close(); }
        }catch(Exception e){}       
    }
}

 

 

>>>>> InsertPrepDB2.java

package prep;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
//import java.sql.ResultSet;
import java.sql.SQLException;

public class InsertPrepDB2 {
    public static void main(String args[]) {
        Connection con=null;
        PreparedStatement  pstmt=null;
        //ResultSet rs=null;

        try {
            //커넥션 연결
            con = DBConnect.getConnection();

            String sql = " INSERT INTO predb(language, db, os) ";
            sql  = sql + " VALUES(?, ?, ?)";

            //쿼리 지정
            pstmt = con.prepareStatement(sql);

            //(물음표의 순번, 적용할 값)
            pstmt.setString(1, "iBATIS");
            pstmt.setString(2, "oracle");
            pstmt.setString(3, "모든 운영체제");

            // 레코드 추가후 1을 ret에 저장
            int cnt = pstmt.executeUpdate();

            System.out.println("레코드 " + cnt + "개가 추가 되었습니다.");
           
        } catch(Exception e) {
            System.out.println("SQLException: " + e.getMessage());
        } finally{
            DBConnect.close(con, pstmt);
        }
    }

}


 

조회 수 :
30755
등록일 :
2013.10.26
15:53:58 (*.251.139.171)
엮인글 :
http://webs.co.kr/index.php?document_srl=32815&act=trackback&key=811
게시글 주소 :
http://webs.co.kr/index.php?document_srl=32815
List of Articles
번호 제목 글쓴이 날짜 조회 수
58 oracle download install 오라클 다운로드 설치 admin 2018-05-29 2377
57 숫자 날짜 문자열 문자 공간 JSON MySQL 자료형 총 정리 phpMyAdmin 자료형 admin 2018-03-26 2738
56 mysql procedure admin 2017-11-16 3799
55 Sqlite very detail easy tutorial I recommand this admin 2017-09-09 4937
54 mysql 로컬접속 풀고 특정 아이피 접속 허가 허락 가능 하게 설정 하는 방법 admin 2017-09-05 4593
53 linux command chmod 리눅스 명령어 가장 쉽게 이해하기 설명 사용자 구룹 타인 권한 admin 2017-09-05 4824
52 mariadb CREATE USER CREATE USER statement creates new MariaDB accounts. admin 2017-09-01 10747
51 MySQL 데이터 베이스 백업 및 복구 방법 admin 2017-09-01 4817
50 Allowing MySQL Root Login from All IP Addresses : admin 2017-08-17 4305
49 Installation of MySQL Database Server admin 2017-08-17 4370
48 mysql 쿼리 로그 남기기 (실시간) admin 2015-04-15 7435
47 SQL Delete records using subqueries admin 2015-04-03 6819
46 Mysql privilege table GRANT SELECT,INSERT,UPDATE,DELETE ON db.table admin 2015-04-02 7068
45 안드로이드 SQLite 속도 향상! insert Transaction admin 2014-04-07 19500
44 MySQL에 원격 접속 허용 여러가지 아이피 아이피대역으로 admin 2014-04-02 28055
43 10gR2_sles10_install file admin 2014-03-18 12698
42 this is final answer assets sqlite Databases trouble copy External DB, check eclips admin 2014-02-18 13469
41 Browse SQLite data on the Android emulator admin 2014-02-15 15060
40 SQLite Database Browser file admin 2014-02-14 13765
39 SQLite Databases using External DB admin 2014-02-14 17588
38 sqlite DB copy admin 2014-02-14 13398
37 Android SQLite Database with Multiple Tables admin 2014-02-13 11870
36 Android Simple Clean Good SQLite Database Tutorial 잘된 설명 admin 2014-02-13 12677
35 android sqlite 사용하기 admin 2014-02-10 24431
34 SQLite 개발가이드 데이터베이스의 성능 admin 2014-02-10 27526
33 android - 다수의 Insert 수행시 속도 향상을 위한 팁 sQlite admin 2014-02-10 20687
32 Oracle Linux 에 Oracle DB 설치하기 admin 2013-12-03 28271
» PreparedStatement mysql java 깔끔한설명 admin 2013-10-26 30755
30 Connect Excel VBA to a MySQL database file admin 2013-09-05 16517
29 Configuring Oracle ASM disks in Oracle Enterprise Linux admin 2013-04-20 14905
28 OS에따른 Oracle 설치버전 admin 2013-04-08 16024
27 RHEL4 + 10g 설치 _silent mode admin 2013-04-08 21774
26 OLE5 + 11G 설치 _silent mode admin 2013-04-08 24990
25 WHERE 조건절 검색시 서브쿼리는 어떻게? admin 2013-04-01 15326
24 CDR 추출 저장 Inner Join 사용 Sql 문 admin 2013-02-05 16138
23 SUPER OCM 1.8club admin 2012-12-18 15707
22 MySQL Java tutorial admin 2012-09-30 23357
21 Oracle 10g Articles admin 2012-06-24 16646
20 기본 10g 설치의 리눅스 세팅에서 추가 해줘야하는 사항(윈도우) admin 2012-06-24 18071
19 SUSE Linux Enterprise Server 10 (Oracle 10g R2 (10.2.0.1)) file admin 2012-03-09 17814
18 Upgrade Oracle from 10.2.0.1 To 10.2.0.4 (Windows) admin 2012-03-06 35547
17 Upgrade Oracle 10g Release 2 from 10201 to 10204 admin 2012-03-05 38657
16 centos 6.2 oracle 10g 설치 admin 2012-03-05 41659
15 Oracle RHEL4+10G 10.2.0.1 설치 10.2.0.5 패치 admin 2012-03-03 28886
14 Oracle Backup & restore with RMAN 기본 admin 2012-02-12 17354
13 오라클 ACE가 해설하는 Oracle Backup & Recovery admin 2012-02-07 17513
12 Oracle Backup & Restore admin 2012-02-07 28449
11 http://www.hoons.kr/ admin 2011-12-19 16974
10 Java && Excel 연동 JAVA 자바로 엑셀을 핸들링 할 수 있는 방법 admin 2011-12-19 80775
9 (C#) ASP.NET MySQL Check Already Exists Add/Insert Record 프로그래밍 코드 admin 2011-12-19 17521