项目中,有很多数据是基本上不变的,同时用到的频率还比较高,如果每次都从数据库读取,不但浪费资源,还影响了系统执行的速度。
所以对于这种数据,基本上是在WEB容器启动的时候,就去数据库读取,放到内存中,用的时候直接从内存里面拿就OK了。
这里有个例子,省市的级联信息,对应的code,name都保存在数据库中的一个地区代码表中,其他表中保存的省市信息,如果没有冗余名称的话,一般都保存地区信息的对应代码。
那么在页面显示的时候,需要把相关的代码转换成省市的名称。这个时候就需要把省市的code--->name对应信息查询出来。
首先在service层配置初始化的bean:
再看RegionServiceImpl.java的代码:
Action里面,从service层取到regionMap,在put到前端页面jsp或者vm
前端页面velocity:
所以对于这种数据,基本上是在WEB容器启动的时候,就去数据库读取,放到内存中,用的时候直接从内存里面拿就OK了。
这里有个例子,省市的级联信息,对应的code,name都保存在数据库中的一个地区代码表中,其他表中保存的省市信息,如果没有冗余名称的话,一般都保存地区信息的对应代码。
那么在页面显示的时候,需要把相关的代码转换成省市的名称。这个时候就需要把省市的code--->name对应信息查询出来。
首先在service层配置初始化的bean:
<bean id="regionService" class="com.xxx.service.impl.RegionServiceImpl"
init-method="initRegion" lazy-init="true"/>
再看RegionServiceImpl.java的代码:
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class RegionServiceImpl implements RegionService {
public RegionDAO regionDAO;
public static Map<String,String> regionMap = new HashMap<String,String>();
public void initRegion(){
if(regionMap.isEmpty()){
List<Region> regionList = regionDAO.getRegions();
for(Region r : regionList){
regionMap.put(r.getCode(),r.getName());
}
}
}
public Map<String,String> getAllRegionMap(){
return getRegionMap();
}
public static Map<String, String> getRegionMap() {
return regionMap;
}
public static void setRegionMap(Map<String, String> regionMap) {
RegionServiceImpl.regionMap = regionMap;
}
}
Action里面,从service层取到regionMap,在put到前端页面jsp或者vm
Map<String,String> regionMap = regionService.getAllRegionMap();
model.addAttribute("regionMap", regionMap);
前端页面velocity:
$regionMap.get(code)