@PersistenceContext注解
private EntityManager em;
注入的是实体管理器,执行持久化操作的,需要配置文件persistence.xml。注入一堆保存实体类状态的数据结构,针对实体类的不同状态(四种,managedh或detached等)可以做出不同的反应(merge,persist等等),其实就是把数据从数据库里提出,然后在内存里处理的,再返回数据库的法则。
javabean与map的转换
1、通过ObjectMapper先将bean转换为json,再将json转换为map,但是这种方法比较绕,且效率很低,经测试,循环转换10000个bean,就需要12秒!!!不推荐使用
2、通过java反射,获取bean类的属性和值,再转换到map对应的键值对中,这种方法次之,但稍微有点麻烦
3、通过net.sf.cglib.beans.BeanMap类中的方法,这种方式效率极高,它跟第二种方式的区别就是因为使用了缓存,初次创建bean时需要初始化,之后就使用缓存,所以速度极快,经测试,循环bean和map的转换10000次,仅需要300毫秒左右。
Maps.newHashMap 和 new HashMap的区别
(1)Map<String, Object> result = new HashMap<String,Object>();
这种是java原生API写法,需要你手动加泛型。
(2)Map<String, Object> result = Maps.newHashMap();
这种是google的guava.jar提供的写法,目的是为了简化代码,不需要你手动写泛型。
public static Map<String , Object> queryCondition(Object param){
Map<String , Object> map = new HashMap<String , Object>();
try{
if (param instanceof Map){
map.putAll((Map<? extends String,?> )param);
}else {
map.putAll(beanToMap(param));
}
}catch(Exception e){
e.printStackTrace();
}
return map;
}
public static <T> Map<String , Object> beanToMap(T bean){
Map<String ,Object> map = Maps.newHashMap();
if (bean != null){
BeanMap beanMap = BeanMap.create(bean);
for (Object key : beanMap.keySet()) {
map.put(String.valueOf(key),beanMap.get(key));
}
}
return map;
}