针对于一定的业务场景,比如页面显示比较复杂的,交互或是联动比较多的场合,
假如对每一个属性都在对应表设定为一个字段,那么可想而知表的字段得有多少了,上百,好几百~~~~
看看就吓人了(虽然确实在对日项目中有见过,一张表一两百字段还是挺常见的,哈哈),
虽然可以采取根据业务小模块分表的设计方式,但是好些张表针对一个页面也是够怪的(并且还有可能是业务类型互斥的场合),
所以大多时候就有了采用oracle的CLOB类型字段!
此处顺便科普一下clob和blob的区别:
BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的。两者都能最大存储4G.
既然采用clob字段来存储的话,就不可避免的需要用到JSON和java Object的相互转换!
相互转换需要用到6个jar包:
核心包:json-lib-2.2.2.jar
依赖包:
commons-lang-2.4.jar
commons-logging-1.1.1.jar
commons-collections-3.2.jar
commons-beanutils-1.7.0.jar
ezmorph-1.0.4.jar
下面是各种封装好的转换方法,以方便使用:
/** * 将Object对象转换成Json对象 * * <pre> * 举例:也可以传入Map * JsonUtil.Object2Json(User user,null) = {"id":"100","userName":"zhangsan",...} * </pre> * * @param object * 传入Object对象 (为空返回null) * @param filterProperty * 过滤属性,过滤掉可能产生的递归属性。(为空不检测) * @return * Json形式的字符串,如果转换异常,返回null。 */ public static String object2Json(Object object, final List<String> filterProperty) { // 传如对象为空返回null; if (object == null) { return null; } try { JsonConfig config = new JsonConfig(); if (!CollectionUtils.isEmpty(filterProperty)) { // Json配置 config.setJsonPropertyFilter(new PropertyFilter() { /** * @see net.sf.json.util.PropertyFilter#apply(java.lang.Object, java.lang.String, java.lang.Object) */ public boolean apply(Object source, String name, Object value) { // 配置可能出现递归的属性 return filterProperty.contains(name); } }); } // 将pojo对象转换成Json对象 JSONObject jsonObject = JSONObject.fromObject(object, config); return jsonObject.toString(); } catch (Exception e) { logger.warn("Object对象转换成Json对象异常:", e); return null; } }
/** * 将Json串转换成Object对象,如果对象中含有其他对象,需要实现的map中注册对象,支持对象的嵌套 * * <pre> * 举例:ObjectA a 里面有3个参数,分别是String a, List<ObjectB> b, ObjectC c ObjectC c中带有参数 ObjectD d * 需要事先定义MAP对象,key值为:参数名 value值为:Class * Map<String, Class> map = new HashMap<String, Class>(); * map.put("b", ObjectB.class); * map.put("c", ObjectC.class); * map.put("d", ObjectD.class); * ObjectA a = (ObjectA)json2Objce(jsonString, ObjectA.class, map); * </pre> * * @param jsonString * Json字符串 * @param beanClass * Bean的class * @param map * 需要到json注册的class集合 * @return * 返回Object对象,如果解析异常,或字符串为空返回null。 */ public static Object json2Object(String jsonString, Class beanClass, Map<String, Class> map) { if (StringUtil.isBlank(jsonString)) { // 如果字符串参数为空返回空对象。 return null; } // 将json对象转换成对象。 JSONObject jsonObjcet = null; try { jsonObjcet = JSONObject.fromObject(jsonString); if (jsonObjcet != null) { // 返回Object对象。 return JSONObject.toBean(jsonObjcet, beanClass, map); } } catch (Exception e) { logger.warn("Json串转换成Object对象异常:Json串:" + jsonString, e); } return null; }
/** * 将array对象转换成Json对象 * * @param object [List,Map均可] * 传入Object对象 (为空返回null) * @param filterProperty * 过滤属性,过滤掉可能产生的递归属性。(为空不检测) * @return * Json形式的字符串,如果转换异常,返回null。 */ public static String arrayObject2Json(Object object, final List<String> filterProperty) { // 传如对象为空返回null; if (object == null) { return null; } try { if (!CollectionUtils.isEmpty(filterProperty)) { // Json配置 JsonConfig config = new JsonConfig(); config.setJsonPropertyFilter(new PropertyFilter() { /** * @see net.sf.json.util.PropertyFilter#apply(java.lang.Object, java.lang.String, java.lang.Object) */ public boolean apply(Object source, String name, Object value) { // 配置可能出现递归的属性 if (filterProperty.contains(name)) { return true; } else { return false; } } }); // 将pojo对象转换成Json对象 JSONArray jsonArray = JSONArray.fromObject(object, config); // 输出String字符串 return jsonArray.toString(); } else { // 将pojo对象转换成Json对象 JSONArray jsonArray = JSONArray.fromObject(object); // 输出String字符串 return jsonArray.toString(); } } catch (Exception e) { logger.warn("array对象转换成Json对象异常:", e); // Json转换异常返回null。 return null; } }
/** * 将Json串转换成Array对象,如果对象中含有其他对象,需要实现的map中注册对象,支持对象的嵌套 * * @param jsonString * Json字符串 * @param beanClass * Bean的class * @param map * 需要到json注册的class集合 * @return * 返回Object数组对象,如果解析异常,或字符串为空返回null。 */ public static Object json2ArrayObject(String jsonString, Class beanClass, Map<String, Class> map) { if (StringUtil.isBlank(jsonString)) { // 如果字符串参数为空返回空对象。 return null; } // 将json对象转换成对象。 JSONArray jsonArray = null; try { jsonArray = JSONArray.fromObject(jsonString); if (jsonArray != null) { // 返回ArrayObject对象。 return JSONArray.toArray(jsonArray, beanClass, map); } } catch (Exception e) { logger.warn("Json串转换成Array对象异常:Json串:" + jsonString, e); // 解析Json字符串异常返回null对象。 return null; } return null; }
/** * 将Json串转换成Map对象,如果Map的value中含有其他对象,需要实现的map中注册对象,支持对象的嵌套 * * @param jsonString Json字符串 * @param beanClass 转换的class,Map LinkedHashMap(支持有序) * @return Map<String, Object>对象 */ private static Map<String, Object> json2Map(String jsonString, Class beanClass) { Map<String, Object> result = null; if (StringUtil.isBlank(jsonString)) { // 如果字符串参数为空返回空对象。 return null; } // 将json对象转换成对象。 try { result = (Map<String, Object>) JSONObject.toBean(JSONObject.fromObject(jsonString), beanClass); } catch (Exception e) { logger.warn("Json串转换成Map对象异常:Json串:" + jsonString, e); // 解析Json字符串异常返回null对象。 return null; } return result; }
以上--------------