反射機(jī)制在JDBC連接中的使用
1、數(shù)據(jù)庫當(dāng)中的表設(shè)計
2、對應(yīng)數(shù)據(jù)表的實(shí)體Bean (id為主鍵)
- public class EnginConfigVO {
- int id = 0;
- int THREADS_COUNT;
- /**
- * @return the id
- */
- public int primaryGetId() {
- return id;
- }
- /**
- * @param id the id to set
- */
- public void primarySetId(int id) {
- this.id = id;
- }
- /**
- * @return the tHREADS_COUNT
- */
- public int getTHREADS_COUNT() {
- return THREADS_COUNT;
- }
- /**
- * @param tHREADS_COUNT the tHREADS_COUNT to set
- */
- public void setTHREADS_COUNT(int tHREADS_COUNT) {
- THREADS_COUNT = tHREADS_COUNT;
- }
- }
由于沒有像hibernate那樣的注解機(jī)制,所以只能在主鍵的setter和getter方法上動動手腳primaryGetId() ,primarySetId(int id)
而實(shí)體bean的類名在與數(shù)據(jù)表的匹配上最后多了“vo” 兩個字母,所以在tb下面方法中將這兩個字母剪裁掉。
反射方法:
T o 對應(yīng)的就是實(shí)體Bean,這樣的方法當(dāng)然是寫在DAO層中,供上層的service調(diào)用,傳入需要修改的實(shí)體Bean
- public <T> void updatePropertiesValues(T o) {
- StringBuilder sd = new StringBuilder("update ");
- sd.append(o.getClass().getSimpleName().toLowerCase().substring(0, o.getClass().getSimpleName().length()-2)).append(" ");
- sd.append("set ");
- StringBuilder id = new StringBuilder("where ");
- try {
- for(Method m : o.getClass().getDeclaredMethods()) {
- String name = m.getName();
- if (name.startsWith("get")) {
- sd.append(name.substring(3).toLowerCase()).append("=");
- if(m.invoke(o) instanceof String) {
- sd.append("'").append(m.invoke(o)).append("', ");
- }else {
- sd.append(m.invoke(o)).append(", ");
- }
- }
- if(name.startsWith("primaryGet")) {
- id.append(name.substring(10).toLowerCase()).append("=");
- if(m.invoke(o) instanceof String) {
- id.append("'").append(m.invoke(o)).append("';");
- }else {
- id.append(m.invoke(o)).append(";");
- }
- }
- }
- sd.delete(sd.length()-2, sd.length());
- sd.append(" ");
- sd.append(id);
- } catch (IllegalArgumentException e) {
- e.printStackTrace();
- } catch (IllegalAccessException e) {
- e.printStackTrace();
- } catch (InvocationTargetException e) {
- e.printStackTrace();
- }
- executeTrans(sd.toString());
- }
這樣以后便可以拼湊出完整的sql語句,為我們解決了功能相似代碼的冗余。。
另外在查找時,我們還可以利用發(fā)射機(jī)制,將數(shù)據(jù)庫返回的resultset 對象包裝成List<T>
- public static <T> List<T> getObjectsList(ResultSet rs, Class<T> k)
- throws SQLException {
- List<T> bl = new ArrayList<T>();
- if (rs != null) {
- while (rs.next()) {
- // System.out.println("result is not null");
- T o = null;
- try {
- o = k.newInstance();
- for (Method m : k.getDeclaredMethods()) {
- String name = m.getName();
- if (name.startsWith("set")) {
- // System.out.println(rs.getObject(name.substring(3)).getClass().getName());
- m.invoke(o, rs.getObject(name.substring(3)));
- }
- }
- bl.add(o);
- } catch (InstantiationException e) {
- e.printStackTrace();
- } catch (IllegalAccessException e) {
- e.printStackTrace();
- } catch (IllegalArgumentException e) {
- e.printStackTrace();
- } catch (InvocationTargetException e) {
- e.printStackTrace();
- }
- }
- return bl;
- }
- return null;
- }
這樣,我們就可以從底層直接獲得包裝好的List<T>集合。。不足之處,歡迎大家討論。。