>  기사  >  Java  >  텍스트 문자열 분할에 대한 자세한 튜토리얼

텍스트 문자열 분할에 대한 자세한 튜토리얼

零下一度
零下一度원래의
2017-06-27 09:39:051183검색

 질문: 프로젝트에서 저장된 데이터가 데이터베이스 필드 열 길이 제한을 초과하는 경우 어떻게 해결합니까?

일반적인 해결책은 문자열 잘림 및 액세스입니다. 이름에서 알 수 있듯이 대용량 텍스트 데이터를 지정된 길이에 따라 가로채고, 반환된 결과 집합은 가로채는 순서대로 새 테이블에 저장됩니다. 그리고 새 테이블에서 가로채는 내용이 이전 테이블의 필드 이름과 일치하는지 식별하기 위해 새 테이블에 유형 필드를 생성함으로써 이전 테이블의 해당 필드는 더 이상 큰 텍스트 데이터를 직접 저장하지 않고 식별자를 저장합니다.

여기에는 텍스트 문자열을 분할하고 다음 단계를 위해 목록 결과 집합을 반환하는 도구 클래스가 제공됩니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.