ホームページ  >  記事  >  Java  >  Java リフレクション テクノロジを使用してオブジェクト指向プログラミングと SQL 操作を接続するにはどうすればよいですか?

Java リフレクション テクノロジを使用してオブジェクト指向プログラミングと SQL 操作を接続するにはどうすればよいですか?

PHPz
PHPz転載
2023-04-23 14:19:08901ブラウズ

サンプルコード:

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[] type=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 if(null!=md[i]){
//调用
属性 attr=dsmd.getAttribute(fd[i].getName().toUpperCase()) ;
if (null ==attr) 続行;
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; はパラメータ配列で、3 番目は返されるオブジェクトの型です。

戻り値はリストであり、リスト内の各オブジェクトは渡したオブジェクト タイプです。

このようなパッケージ化の後、SQL とオブジェクトは自然にカプセル化されます。各クエリ、次に resultset.next()、次に getString()、そして次に setXxx();## を見つける必要はありません。

#もちろん、これはメタデータと Java オブジェクト リフレクション テクノロジの利用における氷山の一角にすぎません。

以上がJava リフレクション テクノロジを使用してオブジェクト指向プログラミングと SQL 操作を接続するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。