真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何用java反射技術將sql操作與面向對象編程關聯(lián)起來

這篇“如何用java反射技術將sql操作與面向對象編程關聯(lián)起來”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“如何用java反射技術將sql操作與面向對象編程關聯(lián)起來”文章吧。

成都創(chuàng)新互聯(lián)公司是專業(yè)的安達網(wǎng)站建設公司,安達接單;提供網(wǎng)站設計、成都網(wǎng)站設計,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行安達網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

實例代碼:

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]){
                       //調(diào)用
                       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;

   }

   //由屬性調(diào)用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方法傳入三個參數(shù),第一個是要查詢的sql語句,第二個是參數(shù)數(shù)組,第三個是要返回的對象類型。

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

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

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

以上就是關于“如何用java反射技術將sql操作與面向對象編程關聯(lián)起來”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關的知識內(nèi)容,請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


本文名稱:如何用java反射技術將sql操作與面向對象編程關聯(lián)起來
當前地址:http://weahome.cn/article/jspgdd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部