일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- DATABASE
- 메이븐업데이트
- 자바연산자
- 오라클
- C언어 표준 라이브러리
- C#접근제한자
- break
- 데이터베이스
- JavaSwing
- mvc디자인패턴
- O(n)
- 자바
- oracle developer
- Oracle SQL Developer
- DEFAULT
- o(log n)
- java
- JSP
- sql
- java접근제어자
- 접근제한자
- DAO
- DTO
- Oracle
- 빅오표기법
- DB 제약조건
- C#접근제어자
- DB
- oracle db
- Vo
성장일기 : 문과생의 개발 여정 (งᐖ)ว ( ᐛ )و
Meta data 본문
package database;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
public class J05_Metadata {
public static void main(String[] args) {
String sql ="SELECT * FROM employees";
try (
Connection conn = JdbcConnection.getConnection();
PreparedStatement pstmt = conn.prepareStatement(sql);
ResultSet rs = pstmt.executeQuery();
){
// 조회한 ResultSet에 대한 정보를 볼 수 있다.
// 실행했을때 쿼리문의 결과가 들어있다.
ResultSetMetaData meta = rs.getMetaData();
System.out.println( "컬럼이 몇개인가?" + meta.getColumnCount());
System.out.println("첫 번째 컬럼의 이름은 무엇인가?" + meta.getColumnLabel(1));
System.out.println("두 번째 컬럼의 이름은 무엇인가?" + meta.getColumnLabel(2));
// 메타데이터는 변수로 꺼내서 사용할 일이 거의 없다.
// 기억이 안날때는 sql developer를 켜서 desc 테이블명 해서 보는게 더 빠를 수 있다.
System.out.println("========================");
for(int i = 1; i <= meta.getColumnCount(); ++i) {
meta.getColumnName(i),
meta.getColumnTypeName(i),
meta.getColumnDisplaySize(i));
//JDBC(Java Database Connectivity)를 사용하여 데이터베이스로부터 데이터를 조회할 때,
// 쿼리의 결과로 반환된 열(column)의 표시 크기, 메서드는 특정 열의 데이터를 표시하는 데 필요한 최대 문자 수 또는 바이트 수를 반환
// 실제 데이터의 길이가 13이므로, 실제 데이터의 길이에 대한 정보는 이 메서드로는 알 수 없고
// 단지 데이터를 표시하는 데 필요한 최대 공간 크기만을 제공
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
'백엔드개발 > JDBC' 카테고리의 다른 글
DB와 연동되는 경품 추첨 이벤트 구현 QUIZ (0) | 2023.11.13 |
---|---|
Data Model Class (0) | 2023.11.13 |
Transaction (0) | 2023.11.13 |
Execute Update (0) | 2023.11.13 |
Prepare Statement (0) | 2023.11.13 |