들어가기 전에
이번 시간엔 JDBC를 이용해 데이터베이스에서 입력/수정/조회/삭제를 하는 프로그램을 만들어 보도록 하겠습니다.
학습 목표
- JDBC를 이용해 입력/수정/삭제/조회 프로그래밍을 할 수 있다.
핵심 개념
- JDBC
- PreparedStatement
- ResultSet
- Connection
학습하기
들어가기 전에
이번 시간엔 JDBC를 이용해 데이터베이스에서 입력/수정/조회/삭제를 하는 프로그램을 만들어 보도록 하겠습니다.
학습 목표
핵심 개념
학습하기
실습코드
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>kr.or.connect</groupId>
<artifactId>jdbcexam</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>jdbcexam</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.45</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.6.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
Role.java
package kr.or.connect.jdbcexam.dto;
public class Role {
private Integer roleId;
private String description;
public Role() {
}
public Role(Integer roleId, String description) {
super();
this.roleId = roleId;
this.description = description;
}
public Integer getRoleId() {
return roleId;
}
public void setRoleId(Integer roleId) {
this.roleId = roleId;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
@Override
public String toString() {
return "Role [roleId=" + roleId + ", description=" + description + "]";
}
}
RoleDao.java - Select
package kr.or.connect.jdbcexam.dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import kr.or.connect.jdbcexam.dto.Role;
public class RoleDao {
private static String dburl = "jdbc:mysql://localhost:3306/connectdb";
private static String dbUser = "connectuser";
private static String dbpasswd = "connect123!@#";
public Role getRole(Integer roleId) {
Role role = null;
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
Class.forName("com.mysql.jdbc.Driver");
conn = DriverManager.getConnection(dburl, dbUser, dbpasswd);
String sql = "SELECT description,role_id FROM role WHERE role_id = ?";
ps = conn.prepareStatement(sql);
ps.setInt(1, roleId);
rs = ps.executeQuery();
if (rs.next()) {
String description = rs.getString(1);
int id = rs.getInt("role_id");
role = new Role(id, description);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (ps != null) {
try {
ps.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
return role;
}
}
jdbcExam1.java - Select
package kr.or.connect.jdbcexam;
import kr.or.connect.jdbcexam.dao.RoleDao;
import kr.or.connect.jdbcexam.dto.Role;
public class JDBCExam1 {
public static void main(String[] args) {
RoleDao dao = new RoleDao();
Role role = dao.getRole(100);
System.out.println(role);
}
}
참고 자료
https://docs.oracle.com
https://docs.oracle.com
comment
제가 뭘 놓친거 같은데... 갑자기 helloworld 찍었는데... 모르겠어요..
role_id =100 일 경우 실행 했을 경우 null 값이 나온경우
오류메시지는 대략
Establishing SSL connection without server's identy verfication is not recommended . 이렇게
RoleDao.java에서
dburl="jdbc:mysql://localhost:3306/connectdb?useSSL=false";로 고쳐주고
mysql 에서
alter user 'connectuser'@'localhost' identified with mysql_native_password by '비밀번호'; 로 해주고 실행해주니
정상적으로 role_id=100 description=Developer 로 출력
에러 공유합니다
1. Establishing SSL connection without server's identity verification is not recommended
-> private static String dburl = "jdbc:mysql://localhost:3306/connectdb?useSSL=false"; 로 수정
2. Unable to load authentication plugin 'caching_sha2_password'.
-> alter user '계정'@'%' identified with mysql_native_password by '패스워드';
저는 위 두개 에러가 순서대로 났었고 저 방법으로 해결했어요
sql 연결했다!! 님들 혹시 안되시면 https://dev.mysql.com/downloads/connector/j/ 여기서 커넥터 다운받아서
https://dhan-description.tistory.com/85 이거보면서 넣어보셔요 저는 이렇게 해결했습니다.
값이 null 뜨시는분들은 exception 오류가 'caching_sha2_password' 이신지 확인해보세요.
->update mysql.user set authentication_string=null where user='connectuser';
FLUSH PRIVILEGES;
exit;
mysql -u connectuser
use mysql;
alter user 'connectuser'@'localhost' identified with caching_sha2_password by '패스워드;
flush privileges;
alter user 'connectuser'@'localhost' identified with mysql_native_password by '패스워드';
flush privileges;
하고 다시 해보세요! 정확한 원인은 모르겠는데 가장 최신 mysql 이면 비밀번호 정책이 바껴서 그런걸수도 .. ㅜ
Establishing SSL connection without server's identity verification is not recommended...
SSL 오류가 나면 url에 "useSSL=false" 추가해 보세요.
"jdbc:mysql://localhost:3306/connectdb?useSSL=false&serverTimezone=UTC";
java.sql.SQLException: Access denied for user 'connectuser'@'localhost' (using password: YES)이 오류때문에 고생하는 분있나요?
현재 위 강의를 실습하시는 분들은 mysql을 비교적 최근에 설치하셨을 텐데요!! 아마 에러가 발생한다면 저와 비슷한 이유일 겁니다.
1. mysql connector java 라이브러리 의존성이 현재 로컬에 설치된 mysql과 맞지 않는다.
해결방법 => mysql-connector-java 라이브러리 의존성을 현재 로컬에 설치된 mysql과 호환되는 버젼으로 올린다.
2. 최신 버젼의 jdbc Driver는 com.mysql.jdbc.Driver가 deprecated 되었음으로 해당 코드를 아래와 같이 바꾼다.
=> Class.forName("com.mysql.cj.jdbc.Driver");
3. Time Zone 에러가 발생한다면 dbURL을 아래와 같이 바꾼다.
=> private static String dbUrl = "jdbc:mysql://localhost:3306/connectdb?serverTimezone=UTC";;
저 말고도 아래에 다양한 해결 방법이 존재하니, 포기하지 마시고 꼭 같이 완주 해봅시다~!!
(이 또한 다 좋은 성장의 밑바탕이 될 꺼에요!!)
제가 인텔리제이를 사용하고 mysql 버전도 달라서 진행하는데 조금 어려움이 있었습니다. 블로그에 정리해놨으니 필요하시면 보세요. (코드와 같은 강의에 포함된 내용은 없습니다)
https://seung00.tistory.com/category/language%20and%20framework/java
너무 좋은 강의 항상 감사합니다
여러분! Time zone 관련된 에러가 발생하는 경우
DB의 주소 뒤에 ?serverTimezone=UTC
을 붙여 주시기 바랍니다^__^다른 분들은 고생하지 않으셨으면 합니다.
mysql 버전 8버전 이상이신분들
<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --> 참고 윗 버전 디펜던시 추가
Dao 에서 클래스 적으실때 업그레이드 된 클래스 네임 적으셔야합니다
Class.forName("com.mysql.cj.jdbc.Driver");
또 JDBCExam1 에서 서버 타임존 에러 뜨시는 분들은 DAO에서
private static String dbUrl = "jdbc:mysql://localhost:3306/connectdb?serverTimezone=UTC";
로 바꿔보세요
궁금한게 있는데
RoleDao.java -select 소스 final 부분에서
finally {
try {
if(rs != null) rs.close();
if(ps != null) ps.close();
if(conn != null) conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
이런식으로 짜면 문제 있나요?
인텔리제이로는 어떻게 하나요?
오류가 뜬다면 참고 바랍니다... 이틀을 해맸네요...
1. 기본 클래스 JDBCExam1 ... 를 찾을 수 없다 ...
=> 이유가 다양한데 제 경우엔 파일 디렉토리 중에 한글이 포함되어서 그랬습니다. 전부 영어(띄어쓰기는 상관 없음)로 바꿔주고 clean 해주니 해결되었습니다.
2. java.sql.SQLException: Unable to load authentication plugin 'caching_sha2_password'.
만들어둔 계정의 암호 플러그인이 caching_sha2_password(기본값) 이어서 발생합니다. mysql에 root 권한으로 접속 후 다음 코드를 실행하면 됩니다.
mysql -h localhost -u root -p mysql (이후 비밀번호 입력)