日期:2014-05-16 浏览次数:20482 次
eval()函数,曾经自己并不觉得怎么样,但是项目中遇到一个需求,被迫使用,感觉确实很强大,记下来,忘了了看看!
?
需求: 1)???????? 省内价格可用精确到地市(即,区号),省外价格只精确到省。(产品表中的产品集合将精确到地市,即一万多产品;非本省操作时,将只显示省名称,实际操作地市产品)。
???????? 2)???????? 产品查询:(查询条件)
?????????????? a)???????? 地区(省内选择地市,省外选择省份)
?????????????? b)???????? 面值
?????????????? c)???????? 运营商
综上:1.jsp页面需要一个二级联动<select>,选择省内时查出当前工号对应省份的所有
??????? 城市,例如:省内(黑龙江)-->查出哈尔滨、齐齐哈尔、大庆等。
??????2.选择省外,查出T_AREA表中所有的省份,例如:黑龙江、辽宁、河南等。
?
一、ServiceImpl中方法
/* 查询所有省号、所有省份名称--去掉重复的,此方法hibernate返回一个Object数组,对distinct 封装了
* @date 2011-5-21 下午04:31:26
*/
@Override
public List<TArea> getProvinceAndCodeList() {
String hql = "select distinct t.provinceCode,t.province from TArea t";
List<TArea> list = queryByHql(hql);
return list;
}
/* 根据区号,查询当前区号对应省内的所有市 集合
* @date 2011-5-21 下午04:57:00
*/
@Override
public List<TArea> getProvinceListByAreaCode(String areaCode) {
String sql = "";
if(null != areaCode && !"".equals(areaCode)){
sql = "select * from t_area t where t.province_code=" +
"(select t1.province_code from t_area t1 where t1.area_code='"+areaCode+"')";
}
List<TArea> list = queryBySql(sql);
return list;
}
?
?
二、struts2的Action两个方法中查询出
??????
?
/**
* 获得当前工号省内的所有--选择的省内
* @author mengxianjun
* @date 2011-5-23 上午09:28:14
*/
public void getAllCity() {
try
{
String area_code = ConfigCtrl.getConfigValue("area_code");//配置表,获得默认区号
tAreaList = areaService.getProvinceListByAreaCode(area_code);//当前工号所在省的所有市集合
this.getResponse().setCharacterEncoding("UTF-8");
PrintWriter out = this.getResponse().getWriter();
JSONArray myjsonObj = JSONArray.fromObject(tAreaList);
out.println(myjsonObj.toString());
out.flush();
out.close();
}
catch( Exception e )
{
log.error("PriceStrategyAction's method getAllCity ",e);
}
}
/**
* 获得所有省--选择的省外
* @author mengxianjun
* @date 2011-5-23 上午09:28:14
*/
public void getAllProvince() {
try
{
allProvinceList = areaService.getProvinceAndCodeList();//所有省集合
this.getResponse().setCharacterEncoding("UTF-8");
PrintWriter out = this.getResponse().getWriter();
JSONArray myjsonObj = JSONArray.fromObject(allProvinceList);
out.println(myjsonObj.toString());
out.flush();
out.close();
}
catch( Exception e )
{
log.error("PriceStrategyAction's method getAllProvince ",e);
}
}
?
?三、jsp页面