大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節(jié)點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 Java學習 Java sql查詢方法

Java sql查詢方法

更新時間:2022-12-01 12:14:51 來源:動力節(jié)點 瀏覽1390次

完成SQL查詢 并將查詢結(jié)果放入Vector容器,以便其他程序使用

/*
* 執(zhí)行sql查詢語句
*/
public static Vector executeQuery(Class clazz, String sql, Object... args) {
Connection conn = null;
PreparedStatement preparedstatement = null;
ResultSet rs = null;
Vector vecRs = new Vector();
T obj = null;
try {
conn = JDBCTools.getConnection();
preparedstatement = conn.prepareStatement(sql);
// 通過sql語句來判斷選擇了那些列
for (int i = 0; i < args.length; i++) {
preparedstatement.setObject(i + 1, args[i]);
}
// 利用sql查詢獲取結(jié)果集
// 利用反射創(chuàng)建實體類的對象
// 獲取結(jié)果街的別名Stud_id 獲取JDBC的元數(shù)據(jù)
// 獲取結(jié)果集每一列的值,結(jié)合上一步得到一個Map鍵值對
// 鍵:列的別名 值:列的值
// 在利用反射對實體類對象的屬性賦值
// 屬性為Map的鍵 值為Map的值
rs = preparedstatement.executeQuery();
// 獲取元數(shù)據(jù)
ResultSetMetaData rsmd = rs.getMetaData();
Map mapMetaData = new HashMap();
// 打印一列的列名
while (rs.next()) {
//獲取數(shù)據(jù)表中滿足要求的一行數(shù)據(jù),并放入Map中
for (int i = 0; i < rsmd.getColumnCount(); i++) {
String columnLabel = rsmd.getColumnLabel(i + 1);
Object columnValue = rs.getObject(columnLabel);
// System.out.println(columnLabel);
mapMetaData.put(columnLabel, columnValue);
}
//將Map中的數(shù)據(jù)通過反射初始化T類型對象
if (mapMetaData.size() > 0) {
obj = clazz.newInstance();
for (Map.Entry entry : mapMetaData.entrySet()) {
String fieldkey = entry.getKey();
Object fieldvalue = entry.getValue();
// System.out.println(fieldkey + ":" + fieldvalue);
ReflectionUtils.setFieldValue(obj, fieldkey, fieldvalue);
//通過反射賦值
}
}
//將對象裝入Vector容器
vecRs.add(obj);
}
}
catch (Exception e) {
e.printStackTrace();
}
return vecRs;
}

其中使用到的工具類方法

獲取數(shù)據(jù)庫連接JDBCTools.getConnection()

/*
* 獲取數(shù)據(jù)庫的連接
*/
public static Connection getConnection() throws Exception {
Connection conn = null;
String driver = null;
String jdbcUrl = null;
String username = null;
String password = null;
// 獲取Properties對象
Properties properties = new Properties();
InputStream in = JDBCTools.class.getClassLoader().getResourceAsStream("jdbc.properties");
properties.load(in);
driver = properties.getProperty("driver");
jdbcUrl = properties.getProperty("jdbcUrl");
username = properties.getProperty("user");
password = properties.getProperty("password");
Class.forName(driver);
conn = DriverManager.getConnection(jdbcUrl, username, password);
return conn;
}
ReflectionUtils.setFieldValue(obj,fieldkey,fieldvalue);

將obj對象的fieldkey屬性賦值為fieldvalue

//設(shè)置對象的屬性
public static void setFieldValue(Object obj,String fieldName,Object value){
Field field=getDeclaredField(obj, fieldName);
if(field==null){
throw new IllegalArgumentException("Could not find field["+
fieldName+"] on target ["+obj+"]");
}
makeAccessiable(field);
try{
field.set(obj, value);
}
catch(IllegalAccessException e){
System.out.println("不可能拋出的異常");
}
}
//判斷field的修飾符是否是public,并據(jù)此改變field的訪問權(quán)限
public static void makeAccessiable(Field field){
if(!Modifier.isPublic(field.getModifiers())){
field.setAccessible(true);
}
}
//獲取field屬性,屬性有可能在父類中繼承
public static Field getDeclaredField(Object obj,String fieldName){
for (Class> clazz=obj.getClass(); clazz!=Object.class; clazz=clazz.getSuperclass()){
try{
return clazz.getDeclaredField(fieldName);
}
catch(Exception e){
}
}
return null;
}

 

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 免费一级a毛片在线播放视 免费一级成人毛片 | 永久免费精品影视网站 | 最新国产午夜精品视频成人 | 4虎最新网址 | 中文字幕 二区 三区 搜查官 | 热99re久久精品2久久久 | 成人a毛片免费视频观看 | 天天干在线影院 | 免费四影虎ww4hu10 | 欧美一区二区三区在线可观看 | 天天干夜夜撸 | 免费观看日本高清a毛片 | 日本中文一二区有码在线观看 | 亚洲手机看片 | 日韩欧美~中文字幕 | 日本免费一区二区三区看片 | 国产精品va | 亚洲国产精品久久久久久网站 | 四虎成人www国产精品 | 国产成人麻豆精品 | 久久精品国产线看观看亚洲 | 成年女人免费观看视频 | 久久免费视频6 | 一级毛片毛片毛片毛毛片 | 国产精品综合网 | 99爱在线精品视频免费观看9 | 国产精品福利视频手机免费观看 | 国产亚洲精品久久久久久久软件 | 亚洲一级毛片免费在线观看 | 青青青青青国产免费观看 | 亚洲乱码国产乱码精品精98 | 免费国产午夜高清在线视频 | 四虎免费在线播放 | 日韩色视频一区二区三区亚洲 | 中文字幕综合久久久久 | 日日摸狠狠的摸夜夜摸 | 色五婷婷| 国产91在线 | 日韩 | 99资源站 | 国产欧美视频在线观看 | 五月天亚洲 |