일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 빌드
- 싱글톤
- 컬렉션
- dependency
- boxing
- 스프링
- 메소드
- 클래스
- 박싱
- suvlet
- 자동형변환
- 루프
- maven
- start.spring.io
- https://start.spring.io
- Short
- Scanner
- bootstrap
- 제네릭
- unboxing
- 내장객체
- Java
- wrapper
- 무한
- 제너릭
- 인텔리제이
- Jenkins
- 콜렉션
- 언박싱
- 싱글턴
Archives
- Today
- Total
Developer Gonie
[7주차] 4. insert 문 실행하기(공통 중요 내용 적어둠)*** 본문
K-DigitalTraining 강의/3. JDBC(Java + Oracle DB)
[7주차] 4. insert 문 실행하기(공통 중요 내용 적어둠)***
이대곤 2022. 6. 20. 16:35* 쿼리문 실행시 명령어별로 사용해야할 메소드가 다름
- executeQuery() 메소드 : select -> 타입의 조회된 결과를 가져온 ResultSet 타입의 객체를 반환한다.
- executeUpdate() 메소드 : insert, update, delete -> 성공적으로 삽입, 수정, 삭제 실행된 개수를 반환함
* executeQuery() 혹은 executeUpdate() 위치에서 에러가 발생한 경우 쿼리문에 오타가 있어서 그럴 가능성이 크다.
* conn.close() 하면 자동으로 commit 됨
1. 가장 원시적으로 insert 문을 실행하는 방법
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class Insert {
public static void main(String[] args) {
String driver = "oracle.jdbc.driver.OracleDriver";
String url = "jdbc:oracle:thin:@localhost:1521:orcl";
String id = "jspid";
String pw = "jsppw";
Connection conn = null;
try {
// 1. 드라이버 로드
Class.forName(driver);
// 2. 계정에 접속
conn = DriverManager.getConnection(url, id, pw);
// 3. 명령어 분석
String sql = "insert into dbtest(num, name, addr) values(6, 'oh', '세종')"; // 여기서는 세미콜론 안씀
PreparedStatement ps = conn.prepareStatement(sql);
// 4. 분석된 명령어를 실행하고 그 결과를 가져옴
int cnt = ps.executeUpdate();
System.out.println("cnt :" + cnt); // 성공적으로 insert 한 개수가 반환됨
// 5. 접속끊기 -> 접속을 끊으면 자동으로 commit됨
conn.close();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
2. 각 컬럼 값을 변수에 담았다가 insert 문을 실행하는 방법1
* 문자열이 컬럼 값으로 들어가야 하는 경우 " ' " 작은 따옴표로 감싸줘야 한다.
// 3. 명령어 분석
int in_num = 5;
String in_name = "lee";
String in_addr = "인천";
String sql = "insert into dbtest(num, name, addr) values(" + in_num + ", '" + in_name + "', '" + in_addr + "')";
PreparedStatement ps = conn.prepareStatement(sql);
3. 각 컬럼 값을 변수에 담았다가 insert 문을 실행하는 방법2(가장 이상적)
* ? 는 위치홀더라고 부른다.
* 분석을 진행한 이후에 set메소드로 물음표 자리를 채워넣는 순서에 주의
// 3. 명령어 분석
int in_num = 6;
String in_name = "sim";
String in_addr = "강원";
String sql = "insert into dbtest(num, name, addr) values(?, ? ,?)";
PreparedStatement ps = conn.prepareStatement(sql);
ps.setInt(1, in_num); // 첫번째 ? 위치에 in_num을 대치한다.
ps.setString(2, in_name); // 두번째 ? 위치에 in_num을 대치한다.
ps.setString(3, in_addr); // 세번째 ? 위치에 in_num을 대치한다.
'K-DigitalTraining 강의 > 3. JDBC(Java + Oracle DB)' 카테고리의 다른 글
[7주차] 6. delete 문 실행하기 (0) | 2022.06.21 |
---|---|
[7주차] 5. update 문 실행하기 (0) | 2022.06.20 |
[7주차] 3. select 문 실행하기 & 출력하기*** (0) | 2022.06.20 |
[7주차] 2. ojdbc.jar 가져와 Java와 DB 연결하기(프로젝트 생성 후 1번씩은 꼭) (0) | 2022.06.20 |
[7주차] 1. JDBC 및 JDBC 드라이버란? (0) | 2022.06.20 |
Comments