将长内容分割,用双主键进行存储

本文介绍了一种利用双主键技术将过长的内容分割并存储到数据库的方法。通过将内容切分为多个部分,每部分不超过1300字符,并为每一部分分配一个序列号,实现了高效的数据存储。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有时候需要保存的内容很长很长,数据库的一个字段无法全部存完,我们就可以使用双主键,将内容分割后再进行存储


//存储内容的主要方法
//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;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值