Posted on 2006-05-16 16:15
qiqijava 閱讀(2058)
評論(5) 編輯 收藏 所屬分類:
Tag
??????????????????????????? ValueList中四個主要的接口與實現類
1. ValueListInfo 封裝Map對象,含有排序、分頁、聚焦和提交表單等相關信息
2. ValueListHandler接口,實現類:DefaultValueListHandlerImpl 它是ValueList中的核心類,其定義在配置文件中,調用getValueList方法返回ValueList對象
3. ValueList接口,實現類:DefaultListBackedValueList 它包含兩個對象,1)域對象的結果集,2)ValueListInfo對象
4. ValueListAdapter接口,有以下幾種實現
?○ DefaultWrapperAdapter???????? jdbc操作的適配器
?○ EventLogAdapter?????????????? 日志操作的適配器
?○ FileSystemAdapter???????????? 文件系統操作的適配器
?○ HibernateAdapter????????????? hibernate操作的適配器
?○ MappingSqlQueryAdapter??????? iBATIS的sqlMap適配器
?
具體實現流程
第一步:從請求中構造ValueListInfo對象,由幫助類ValueListRequestUtil實現
?從請求中取得URL的參數和系統默認值來構造ValueListInfo對象
?
第二步:得到Adapter的實現類
?調用getBean方法,從配置文件中取得ValueListHandler實現類,調用getValueList方法,得到實體key對應的Adapter,如:
?<bean class="net.mlw.vlh.adapter.hibernate3.HibernateAdapter">
??<property name="sessionFactory"><ref bean="mySessionFactory"/></property>
??<property name="defaultNumberPerPage"><value>10</value></property>
??<property name="defaultSortColumn"><value>messageIn.date</value></property>
??<property name="defaultSortDirection"><value>desc</value></property>
??<property name="hql">
??<value>
??from User AS vo
???/~certNumber: where vo.certNumber like {certNumber} ~/
???/~name: where vo.name like {name} ~/
???/~certHolder: where vo.certHolder like {certHolder} ~/
???/~groupName: where vo.group.name like {groupName} ~/
???/~sortColumn: ORDER BY vo.[sortColumn] [sortDirection]~/
??</value>
??</property>
??<property name="defaultFocusPropertyObjectAlias"><value>vo</value></property>
??<property name="maxRowsForFocus"><value>160000</value></property>??
??<property name="removeEmptyStrings"><value>true</value></property>
?</bean>
第三步:構造ValueList對象,使用DefaultListBackedValueList實現類
?用適配器取得結果集(如HibernateAdapter),封裝ValueList對象
?ValueList中包含兩個對象,1)域對象的結果集,2)ValueListInfo對象(分頁的相關息)
?
第四步:把ValueList對象放到WEB的作用域中
HQL說明:主要通過迭代動態生成HQL語句
from User AS vo
?/~certNumber: where vo.certNumber like {certNumber} ~/?????????? (1)
?/~name: where vo.name like {name} ~/???????????????????????????? (2)
?/~certHolder: where vo.certHolder like {certHolder} ~/?????????? (3)
?/~groupName: where vo.group.name like {groupName} ~/???????????? (4)
?/~sortColumn: ORDER BY vo.[sortColumn] [sortDirection]~/???????? (5)
(1)如果ValueListInfo中包含certNumber變量,如certNumber=100,則vo.certNumber like=100,生成HQL=from User AS vo where vo.certNumber like=100;
??????? 如果ValueListInfo中不包含certNumber變量,生成HQL=from User AS vo?? (1)行由空白代替
其它以此類推
注意:傳給HQL的每個變量都要單獨占一行,就算是類似between and 的語句也要分兩行寫