데이터셋의 사이즈 제한이 있음을 참고하시기 바랍니다.
데이터셋 전체에 대한 건수 제한은 없으나(컬럼수 제한 없음, 로우수 제한 없음), 데이터 사이즈에 제약이 있습니다.
1컬럼에 최대 6K, 1로우에 8K를 넘을 수 없습니다.
자세한 내용은 컴포넌트 매뉴얼의 DataSet 항목을 참고하세요.
------------- DataSet -------------
DataSet은 데이터 처리를 담당하는 컴포넌트입니다.
사용자가 입력한 Data를 Server에 전달하거나 Server에서 생성된 Data를 수신하는 역할을 수행합니다.
이런 Data처리를 담당하는 DataSet은 처리할 수 있는 Data size에 제약을 가지고 있는데 한 컬럼당 최대 6K, 한 로우당 8K의 제약을 가지고 있습니다.
예를 들어 컬럼 A, B, C 로 구성된 DataSet에 첫번째 Row의 Data로 A : 6K, B: 3K, C: 2K의 Data를 담아 Client로 전송하게 되면 한 Row의 Data량이 11K가 되어 한 Row에서 처리할 수 있는 8K의 용량을 초과하게 됩니다.
이럴 경우 Client에서는 Memory 문제가 발생될 수 있습니다.
이를 방지하기 위해서는 개발시 Data를 세팅하는 부분에 유효한 Data의 Size를 알고(보통 DB Schema 참조) 적정한 사이즈를 세팅해 주어야 합니다.
한 컬럼, 컬럼들의 합인 한 로우에 대한 사이즈 제약은 있지만, DataSet에서 처리할 수 있는 전체 size에 대한 제약은 없습니다.
단, 유니코드인 경우 Data Type이 String일 경우 Column Size에 *2(또는 *3)를 하게 됩니다.
예를 들어 A:STRING(3000), B:STRING(2000), C: INT(10)의 Data를 담아 Client로 전송하게 되면 3000*2 + 2000*2 + 10 되어 10.01K가 되어 처리할 수 있는 8K의 용량을 초과하게 됩니다.
>헤더 설정을 통해 사이즈를 크게 해도 안되고,
>Edit형식이 아닌데 Edit형식으로 변경도 해보고 EditLimit, EditLimitText 도 값을 줘 봤지만 아무런 변화가 없습니다.
>특이한 사항은..
>데이터가 90개일때는 잘려서 나왔고, 36개일때는 제대로 나옵니다. 물론 한개만 나오도록 해도 제대로 나오구요.
>또 한가지는...
>builder.getColumn("name").setSize(5000); 이런 구문 없이 flush를 했을경우에는
>36개 데이터에서도 잘려서 나왔다는 겁니다.
>
>** action 부분 소스
> GauceBuilder builder = new GauceBuilder();
> builder.prepare(greq, gres);
> builder.buildWithUptColumn(VOList, VO.class,10);
> builder.getColumn("name").setSize(5000);
> builder.flush();
>
>아래 답변외에 다른 원인이나 해결방법은 없나요?
>비슷한 현상의 샘플 소스가 있다면 공유 부탁드립니다.
>
>
>
>>데이터셋의 헤더에서 해당 컬럼의 사이즈를 어떻게 지정하셨는지 확인하시기 바랍니다.
>>데이터셋의 헤더 사이즈에 문제가 없다면 그리드 컬럼 속성에서 EditLimit, EditLimitText 를 설정하셨는지도 확인하시기 바랍니다.
>>
>>
>>>게시판을 이용해 주셔서 감사합니다.
>>>다음양식에 맞게 입력해주세요.
>>>
>>>* 고객시스템명 : GDLS
>>>* GAUCE 버전 : 4.0
>>>* WAS 종류(WebLogic 등등) : WebLogic
>>>* DB 종류 : 오라클
>>>* 문의 유형(질문/요청/참조) : 질문
>>>* 내용 :
>>>데이터베이스에서 Select 해온 데이터와 그리드에 뿌려지는 데이터가 다릅니다.
>>>길이가 긴 데이터는 중간에 짤려서 그리드에 표현됩니다.
>>>예를 들면..)
>>>no, name
>>>1, 'abcd'
>>>2, 'abcde'
>>>3, 'abcdefghrjklmn'
>>>이런식으로 Select 가 되었다면 (실제로는 훨신 긴 데이터임)
>>>그리드에 표현되는 것은 아래처럼.
>>>no, name
>>>1, 'abcd'
>>>2, 'abcde'
>>>3, 'abcdefgh'
>>>맨 마지막 name 컬럼의 데이터가 잘렸습니다.
>>>
>>>action 단에서 builder.getColumn("name").setSize(5000); 이런식으로 변경했는데도 마찬가지네요.
>>>데이터가 잘리지 않도록 하는 방법이 없을까요?
>>
>