项目中,有很多数据是基本上不变的,同时用到的频率还比较高,如果每次都从数据库读取,不但浪费资源,还影响了系统执行的速度。
所以对于这种数据,基本上是在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)??