Java反射_JDBC操作資料

來源:互聯網
上載者:User

標籤:

使用反射 來操作  這裡是練習反射的使用資料庫工具類

  1. private static final String DRIVER = "com.mysql.jdbc.Driver";  
  2.     private static final String USER = "root";  
  3.     private static final String PW = "1234";  
  4.     private static final String URL="jdbc:mysql://localhost:3306/reflction";  
  5.     /** 
  6.      * 連結資料庫 
  7.      * @return 
  8.      */  
  9.     public static Connection getConnection(){  
  10.         try {  
  11.             Class.forName(DRIVER);  
  12.             Connection con = DriverManager.getConnection(URL, USER, PW);  
  13.             System.out.println("Connection OK .....");  
  14.             return con;  
  15.         } catch (Exception e) {  
  16.             System.out.println("Connection error...");  
  17.             e.printStackTrace();  
  18.         }  
  19.         return null;  
  20.     }  

public Object getById(Class clazz, Integer id) throws Exception{
Object obj = clazz.newInstance();//實列一個
//建立連結
Connection con = JdbcUtils.getConnection();
//擷取實體的名字 需要拼接 從最後一個點開始
String tablename = clazz.getName().substring(clazz.getName().lastIndexOf("."));
//拼接sql 語句
String sql = "select * from "+tablename+" where id=?";

try {
PreparedStatement psmt = con.prepareStatement(sql);
psmt.setInt(1, id);
//查到結果集
ResultSet rs = psmt.executeQuery();
//遍曆結果
while(rs.next()){
//得到所有屬性
Field[] fields = clazz.getDeclaredFields();
for (Field field : fields) {//遍曆屬性
//擷取屬性名稱
String fname = field.getName();
//擷取屬性類型 int
Class type = field.getType();
//
Method rsGetMethod = ResultSet.class.getMethod("getObject", String.class);
Object value = rsGetMethod.invoke(rs, fname);
//更改修飾符許可權
field.setAccessible(true);
field.set(obj, value);
}

交流群: 386451316

原文地址:http://blog.csdn.net/u010982856/article/details/40151021

Java反射_JDBC操作資料

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.