有时候需要保存的内容很长很长,数据库的一个字段无法全部存完,我们就可以使用双主键,将内容分割后再进行存储
//存储内容的主要方法 //Entity为假设的,使用双主键的实体,其主键实体为EntityPK //content为需要进行存储的内容 private List<Entity> genEntityList(Entity entity,String content) { List<Entity > entity= new ArrayList<Entity >(); Map<String, Object> query=new HashMap<String, Object>(); // 将字符串按4000的长度进行分割 int maxLen = 1300; // 需要分割的次数 int twices = content.length() / maxLen; twices++; //getEntityId方法用于获取id(插入方法中就不要配置生成id了) //语句如下:SELECT SEQ_ENTITY.NEXTVAL FROM DUAL List idlist=entityService.queryList("getEntityId", null); String id=idlist.get(0).toString(); for (int i = 0; i < twices; i++) { int beginIdx = i * maxLen; int endIdx = (i + 1) * maxLen; String EntCon = content.substring(beginIdx, endIdx > content.length() ? content.length() : endIdx); Entity bEntity = newEntity (); EntityPK pk = newEntityPK (); pk.setId(id); pk.setSeqnum(i + ""); bEntity .setPk(pk); bEntity .setEntCon(EntCon ); entity.add(bCfgMessageIn); } return entity; }
//在方法中进行调用 //相关表中用一个字段关联一下Entity的Id public void setContent() { ……//do something List<Entity> list=genEntityList(entity, content); entityService.insertInBatch(list); }
//dao中的insertInBatch方法 @Override public int insertInBatch(List<T> entityList) { if (entityList == null || entityList.isEmpty()) return 0; int i=0; for (T entity : entityList) { i+=this.insert(entity); } return i; }