91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么利用Java反射技術將面向對象編程和SQL操作聯系起來

發布時間:2023-05-10 09:25:16 來源:億速云 閱讀:147 作者:zzz 欄目:編程語言

本篇內容介紹了“怎么利用Java反射技術將面向對象編程和SQL操作聯系起來”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

實例代碼:

public class SqlUtil extends BaseApplogic {
   public List excuteQuery(String sql, Object[] paras, Object voo)
           throws AppException {
       DBPersistenceManager dbpm = this.getFnmsDBPM();
       List list=new ArrayList();
       try {
           DataSet ds = (DataSet) dbpm.executeQuery(sql, paras);
           
           DataSetMetaData dsmd = ds.getDataSetMetaData();
           
           Field[] fd = voo.getClass().getDeclaredFields();
           String className = voo.getClass().getName();
           int size = fd.length;
           Method md[]=new Method[size];
           //構造method[]
           for (int i = 0; i < size; i++) {
               Attribute attr=dsmd.getAttribute(fd[i].getName().toUpperCase());
               if (null != attr) {
                   Field f = voo.getClass().getDeclaredField(fd[i].getName());
                   String type = f.getType().getName();
                   Class[] types=getTypes(type);  
                   String methodName=getSetterName(fd[i].getName());
                   md[i] = voo.getClass().getMethod(
                           methodName,types);
               }
           }
           
           while(ds.next()){
               Object o = Class.forName(className).newInstance();
               for (int i = 0; i < size; i++) {
                   if(null!=md[i]){
                       //調用
                       Attribute attr=dsmd.getAttribute(fd[i].getName().toUpperCase());
                       if (null==attr) continue;
                       Object[] pa=new Object[]{ds.getString(attr.getAttrName())};
                       md[i].invoke(o,pa);
                   }
               }
               list.add(o);
           }
       } catch (DrmException drme) {
           this.handleException(drme);
       } catch (Exception e) {
           this.handleException(e);// 新增加的異常處理
       } finally {
           if (dbpm != null) {
               dbpm.close();
           }
       }
       return list;
   }
   //由屬性調用set方法
   public static String getSetterName(String propName) {
       return "set" + propName.substring(0, 1).toUpperCase()
               + propName.substring(1, propName.length());
   }
   // 取類型
   public static Class[] getTypes(String type) {
       if (type.equals("java.lang.String")) {
           return new Class[] { String.class };
       } else if (type.equals("int")) {
           return new Class[] { Integer.TYPE };
       } else if (type.equals("long")) {
           return new Class[] { Long.TYPE };
       } else if (type.equals("float")) {
           return new Class[] { Float.TYPE };
       } else {
           System.out.println("no such type!");
           return null;
       }
   }
}

其中excuteQuery方法傳入三個參數,第一個是要查詢的sql語句,第二個是參數數組,第三個是要返回的對象類型。

返回值是一個list,list中的每個對象都是你傳入的對象類型。

經過這樣一種包裝,將sql與對象自然的封裝起來,不用每個查詢都查出來以后,再resultset.next(),再getString(),然后再setXxx();

當然,這只是元數據與java對象反射技術利用的冰山一角。

“怎么利用Java反射技術將面向對象編程和SQL操作聯系起來”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

广安市| 天气| 富裕县| 潼关县| 岳阳县| 年辖:市辖区| 萝北县| 乌鲁木齐县| 长海县| 八宿县| 虎林市| 越西县| 图片| 松阳县| 内江市| 辽阳县| 安丘市| 板桥市| 新乐市| 宁波市| 贵溪市| 龙岩市| 敦化市| 安泽县| 冀州市| 涞源县| 正宁县| 固始县| 扬州市| 祁连县| 菏泽市| 安新县| 江津市| 枞阳县| 云阳县| 额尔古纳市| 酒泉市| 临海市| 错那县| 台中市| 新巴尔虎左旗|