자바 범용 및 데이터베이스 응용 실례 상세 설명
눈여겨보다
BaseDao 는 기본 적 인 데이터 베 이 스 를 추가 삭제 하고 수정 한 후에 이 범 형 류 를 계승 하여 각자 의 추가 삭제 와 수정 을 실현 하거나 초 류 의 추가 삭제 와 수정 을 사용 할 수 있 으 며 모든 계승 류 는 자신의 조작 도 증가 할 수 있다.
실전
1 BaseDao.java
import java.lang.reflect.Field;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
public class BaseDao<T> {
Connection connection;
PreparedStatement pStatement;
String urlString = "jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=UTF8";
String drivString = "com.mysql.jdbc.Driver";
void OpenDB() {
try {
if (connection == null) {
Class.forName(drivString);
this.connection = DriverManager.getConnection(urlString, "root", "123456");
}
} catch (Exception e) {
e.printStackTrace();
}
}
void CloseDB() {
try {
if (pStatement != null) pStatement.close();
if (connection != null) connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
public void Save( T t ) {
OpenDB();
String table = "";
String sqlString = "insert into ";
try {
table = t.getClass().getSimpleName();
Field[] fields = t.getClass().getDeclaredFields();
sqlString += table;
String sqlNameString = "";
String sqlValString = "";
for (Field field : fields) {
sqlNameString += field.getName() + ",";
sqlValString += "?,";
}
sqlNameString = sqlNameString.substring(0, sqlNameString.length() - 1);
sqlValString = sqlValString.substring(0, sqlValString.length() - 1);
pStatement = connection.prepareStatement(sqlString + " (" + sqlNameString + ") values (" + sqlValString + ")");
int n = 1;
for (Field field : fields) {
field.setAccessible(true);
System.out.println(field.get(t).toString());
pStatement.setString(n, field.get(t).toString());
n++;
}
pStatement.executeUpdate();
CloseDB();
} catch (Exception e) {
e.printStackTrace();
CloseDB();
}
}
public void Del( T t ) {
}
public void Update( T t ) {
}
public void Search( T t ) {
}
}
2 StudentDao.java
public class StudentDao extends BaseDao<Student> {
}
3 TeacherDao.java
public class TeacherDao extends BaseDao<Teacher> {
}
4 Student.java
public class Student {
public String name;
public int age;
public String dept;
/**
* @return the name
*/
public String getName() {
return name;
}
/**
* @param name the name to set
*/
public void setName(String name) {
this.name = name;
}
/**
* @return the age
*/
public int getAge() {
return age;
}
/**
* @param age the age to set
*/
public void setAge(int age) {
this.age = age;
}
/**
* @return the dept
*/
public String getDept() {
return dept;
}
/**
* @param dept the dept to set
*/
public void setDept(String dept) {
this.dept = dept;
}
}
5 Teacher.java
public class Teacher {
}
6 TestDao.java
public class TestDao {
public static void main(String[] args) {
System.out.println("ok");
Student stud=new Student();
stud.age=20;
stud.name="zhangsan";
stud.dept="computer";
StudentDao sd=new StudentDao();
sd.Save(stud);
System.out.println(stud.dept);
}
}
삼 운행ok
zhangsan
20
computer
computer
4.어떻게 IDEA 에서 jar 가방 을 가 져 옵 니까?
부록 참고 가능:IDEA 연결 데이터베이스(jar 패키지 가 져 오기)
오 별 표기 법
StudentDao.java
public class StudentDao<M> extends BaseDao<M> { // M
}
TestDao.java
public class TestDao {
public static void main(String[] args) {
System.out.println("ok");
Student stud=new Student();
stud.age=20;
stud.name="zhangsan2";
stud.dept="computer";
StudentDao<Student> sd=new StudentDao<>(); // Student
sd.Save(stud);
System.out.println(stud.dept);
TeacherDao<Teacher> te= new TeacherDao<>();
}
}
첨부:IDEA 연결 데이터베이스(jar 패키지 가 져 오기) 자바 가 MySQL 에 연결 하려 면 드라이버 패키지 가 필요 합 니 다.최신 버 전 다운로드 주 소 는 http://dev.mysql.com/downloads/connector/j/ 입 니 다.압축 을 풀 고 jar 라 이브 러 리 파일 을 받 은 다음 해당 항목 에서 이 라 이브 러 리 파일 을 가 져 옵 니 다.
IDEA jar 가 져 오기 프로 세 스:새 폴 더(이름 임 의,여 기 는 Lib 사용),mysql-connector-java-*.*.**-bin.jar 다음 그림 가 져 오기
jar 파일 을 오른쪽 클릭 하고 Add as Library 를 누 르 면 jar 가 져 오기 에 성공 합 니 다.뒤에 바 이 두 자바 가 my sql 을 사용 하면 my sql 에 상세 하 게 접근 하 는 코드 가 있 습 니 다.
ecplice jar 프로 세 스 가 져 오기:새 폴 더(이름 임 의,여 기 는 Lib 사용),mysql-connector-java-*.*.**-bin.jar 다음 그림 가 져 오기
오른쪽 키->buildpath->add to build path
더 많은 자바 관련 내용 에 관심 이 있 는 독자 들 은 본 사이트 의 주 제 를 볼 수 있 습 니 다.
본 고 에서 말 한 것 이 여러분 의 자바 프로 그래 밍 에 도움 이 되 기 를 바 랍 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JPA + QueryDSL 계층형 댓글, 대댓글 구현(2)이번엔 전편에 이어서 계층형 댓글, 대댓글을 다시 리팩토링해볼 예정이다. 이전 게시글에서는 계층형 댓글, 대댓글을 구현은 되었지만 N+1 문제가 있었다. 이번에는 그 N+1 문제를 해결해 볼 것이다. 위의 로직은 이...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.