問題:在專案中,當儲存資料超過資料庫欄位列長度限制時,如何解決?
常見的解決方法是:截串存取。顧名思義,就是將大文本資料依指定長度截取,回傳結果集依截取順序儲存在新表中。並且透過在新表中建立一個type字段來標識新表中截取的內容對應舊表中的字段名,而舊表中相應的字段不再直接存放大文本數據,而是存放標識符。
這裡,提供一個工具類,用來分割文字字串,傳回List結果集供下一步使用。
public class StringUtil {/** * @Name: getContentByList * @Description: 字符串切割 * @Author: 张(作者) * @Version: V1.00 (版本号) * @Create Date: 2017-6-26(创建日期) * @Parameters: wholecontent:传递的文本字符串; cutcount:切割字符串的长度 * @Return: List:切割字符串形成的集合,存放结果集*/public static List<String> getContentByList(String wholecontent,int cutcount){ List<String> list = new ArrayList<String>();//获取完整内容字符串的总长度int contentlen = wholecontent.length(); //内容截取,用内容总长和截取长度进行比较,无须截取的话直接插入if (contentlen < cutcount){ list.add(wholecontent); }//内容长度超过截取长度else{//定义并初始化内容段落String contentpart ="";//定义并初始化被截取的段落数量int contentround =0;//开始截取的位置int begincount = 0; //判断截取的段落数 int contentcutpart = contentlen/cutcount; int contentcutparts = contentlen%cutcount; //求余数//若余数为0,说明被整除,内容的长度正好是截取长度的倍数。if (contentcutparts==0){ contentround = contentcutpart; }else{ contentround = contentcutpart+1; }//循环截取内容for (int i = 1; i <= contentround; i++) {//如果不是最后一个截取部分if (i != contentround){//按照截断长度截取内容contentpart = wholecontent.substring(begincount, cutcount*i); }else{//截取最后一部分内容contentpart = wholecontent.substring(begincount, contentlen); }//赋值下一截取部分的起点位置 begincount = cutcount*i; list.add(contentpart); } }return list; } }
以上是詳解分割文字字串的實例教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!