mysql增删改查 dao_MYSQL 之 JDBC(七):增删改查(五) DAO设计模式
Data Access Object,數(shù)據(jù)訪問對(duì)象
what:訪問數(shù)據(jù)信息的類。包含了對(duì)數(shù)據(jù)的CRUD(create、read、update、delete,增刪改查)操作,而不包含任何業(yè)務(wù)相關(guān)的信息。
why:實(shí)現(xiàn)功能的模塊化。更有利于代碼的維護(hù)和升級(jí)。DAO可以被子類集成或直接使用
how:使用JDBC編寫DAO可能會(huì)包含的方法:
void update()
// insert, update, delete 操作都可以包含在其中
void update(String sql, Object ... args)
查詢
// 查詢一條記錄,返回對(duì)應(yīng)的對(duì)象
T get(Class clazz, String sql, Object ... args)
// 查詢多條記錄,返回對(duì)應(yīng)的對(duì)象的集合
List getForList(Class clazz, String sql, Object ... args)
// 返回某條記錄的某一個(gè)字段的值或一個(gè)統(tǒng)計(jì)的值(一共有多少記錄等。)
E getForValue(String sql, Object ... args)
代碼實(shí)現(xiàn)
DAO
package com.litian.jdbc;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* @author: Li Tian
* @contact: litian_cup@163.com
* @software: IntelliJ IDEA
* @file: DAO.java
* @time: 2020/3/26 18:37
* @desc: |
*/
public class DAO {
// insert, update, delete 操作都可以包含在其中
void update(String sql, Object... args) {
Connection conn = null;
PreparedStatement ps = null;
try {
conn = JDBCTools.getConnection();
ps = conn.prepareStatement(sql);
for (int i = 0; i < args.length; i++) {
ps.setObject(i + 1, args[i]);
}
ps.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCTools.release(null, ps, conn);
}
}
// 查詢一條記錄,返回對(duì)應(yīng)的對(duì)象
T get(Class clazz, String sql, Object... args) {
T entity = null;
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
// 1. 獲取Connection
conn = JDBCTools.getConnection();
// 2. 獲取PreparedStatement
ps = conn.prepareStatement(sql);
// 3. 填充占位符
for (int i = 0; i < args.length; i++) {
ps.setObject(i + 1, args[i]);
}
// 4. 進(jìn)行查詢,得到ResultSet
rs = ps.executeQuery();
// 5. 若ResultSet中有記錄,準(zhǔn)備一個(gè)Map: 鍵:存放列的別名;值:存放列的值
if (rs.next()) {
Map values = new HashMap<>();
// 6. 得到ResultSetMetaData對(duì)象
ResultSetMetaData rsmd = rs.getMetaData();
// 7. 處理ResultSet,把指針向下移動(dòng)一個(gè)單位
// 8. 由ResultSetMetaData對(duì)象得到結(jié)果集中有多少列
int columnCount = rsmd.getColumnCount();
// 9. 由ResultSetMetaData得到每一列的別名,由ResultSet得到具體每一列的值
for (int i = 0; i < columnCount; i++) {
String columnLabel = rsmd.getColumnLabel(i + 1);
Object columnValue = rs.getObject(columnLabel);
// 10. 填充Map對(duì)象
values.put(columnLabel, columnValue);
}
// 11. 用反射創(chuàng)建Class對(duì)象的對(duì)象
entity = clazz.newInstance();
// 12. 遍歷Map對(duì)象,用反射填充對(duì)象的屬性值:屬性名為Map中的Key,屬性值為Map中的Value
for (Map.Entry entry : values.entrySet()) {
String propertyName = entry.getKey();
Object value = entry.getValue();
ReflectionUtils.setFieldValue(entity, propertyName, value);
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCTools.release(rs, ps, conn);
}
return entity;
}
// 查詢多條記錄,返回對(duì)應(yīng)的對(duì)象的集合
List getForList(Class clazz, String sql, Object... args) {
return null;
}
// 返回某條記錄的某一個(gè)字段的值或一個(gè)統(tǒng)計(jì)的值(一共有多少記錄等。)
E getForValue(String sql, Object... args) {
return null;
}
}
DAO測(cè)試
package com.litian.jdbc;
import java.sql.Date;
import java.sql.Timestamp;
/**
* @author: Li Tian
* @contact: litian_cup@163.com
* @software: IntelliJ IDEA
* @file: DAOTest.java
* @time: 2020/3/26 18:59
* @desc: |
*/
public class DAOTest {
public static void main(String[] args) {
DAO dao = new DAO();
// 測(cè)試update
// String sql = "insert into t_user(id, username, pwd, regTime, lastLoginTime) values(?,?,?,?,?)";
// dao.update(sql, 4, "李英俊", "123456", new Date(System.currentTimeMillis()), new Timestamp(System.currentTimeMillis()));
// 測(cè)試get
String sql = "select id, username, pwd, regTime, lastLoginTime from t_user where id=?";
User u = dao.get(User.class, sql, 4);
System.out.println(u);
}
}
總結(jié)
以上是生活随笔為你收集整理的mysql增删改查 dao_MYSQL 之 JDBC(七):增删改查(五) DAO设计模式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 可以上牌的老年四轮代步车有哪些品牌?
- 下一篇: mysql数据库存储引擎选择_MySQL