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