『壹』 java反射取對象屬性值 不是通過get方法取值
反射不是通過get取值的,是通過該對象的信息,比如說名稱、內存地址等來訪問類,方法,屬性等,可以獲取任意對象的信息,但不能獲得私有屬性(private String s=「sd」;)的值,切記
推薦《JAVA核心技術》這本書會對你有幫助的
『貳』 如何java編程實現提取資料庫中的表的屬性值,並可視化出來。比如說創建了一張表,屬性有id、name等等
思路:你先建立資料庫連接:連接資料庫的方式你應該會吧。不會在網上查一下,獲取連接後:拿到連接對象:如下:
Connection conn = DriverManager.getConnection(url,userName,password);
//實現關於資料庫的整體綜合信息對象:如下:
java.sql.DatabaseMetaData dbmd=conn.getMetaData();
//獲取資料庫相關的信息,
System.out.println("資料庫產品名: "+dbmd.getDatabaseProctName());
System.out.println("資料庫是否支持事務: "+dbmd.supportsTransactions());
System.out.println("資料庫產品的版本號:"+dbmd.getDatabaseProctVersion());
//獲取全表相關的信息
ResultSet tSet=dbmd.getTables(null,"%","%",newString[]{"TABLE","VIEW"})
while(tSet.next()){
System.out.println(tSet.getRow()+"_表類別:"+tSet.getString("TABLE_CAT")+"_表模式:"+tSet.getString ("TABLE_SCHEM")+"_表名稱:"+tSet.getString("TABLE_NAME")+"_表類型:"+tSet.getString("TABLE_TYPE")
}
//獲取表的主鍵列信息;
ResultSetprimaryKey=dbmd.getPrimaryKeys("MANOR","PUBLIC","SYS_ROLE_RES");
while(primaryKey.next()){
System.out.println("表名:"+primaryKey.getString("TABLE_NAME")+",列名:"+primaryKey.getString("COLUMN_NAME")
+" 主鍵名:"+primaryKey.getString("PK_NAME"));
//其中表名:SYS_ROLE_RES,
}
//獲取表的外鍵列信息"
ResultSet foreinKey=dbmd.getImportedKeys("MANOR","PUBLIC","SYS_ROLE_RES");
while(foreinKey.next()){
System.out.println("主鍵名:"+foreinKey.getString("PK_NAME")+",外鍵名:"+foreinKey.getString("FKCOLUMN_NAME")
+",主鍵表名:"+foreinKey.getString("PKTABLE_NAME")+",外鍵表名:"+foreinKey.getString("FKTABLE_NAME")
+",外鍵列名:"+foreinKey.getString("PKCOLUMN_NAME")+",外鍵序號:"+foreinKey.getString("KEY_SEQ"));
}
相獲取更多SQL參數,可參考資料庫相關方面的教材。
『叄』 java怎麼通過反射獲得所有的屬性的值
Class<?> clazz = ref.getClass();
Method method=clazz.getMethod("getLength");
System.out.println(method.invoke(ref));
『肆』 java如何循環可以可以獲取到每個屬性的值 ,不要用對象名.get屬性名這種方式獲取
覆蓋模型層對象的toString方法,進行重寫,寫有意義的內容,把屬性全都寫進去,
然後直接對象.toString()把所有的列印出來
給你文檔最後一條參考
『伍』 Java獲取泛型對象中的某個屬性值
首先做一個介面,介面中聲明需要的取值方法
然後做你要的實際的類,每個類實現不同的取值方法
然後list通過介面進行定義,將每個實際類的對象insert到list中間
然後利用多態實現動態的方法綁定,實現你的需求