답변 주셔서 감사드립니다.
그러나 제가 의도한 질문을 오해하시나 봅니다.
"데이터가 90개일때는 잘려서 나왔고, 36개일때는 제대로 나옵니다. 물론 한개만 나오도록 해도 제대로 나오구요."라는 얘기는 컬럼 내의 데이터개수를 의미한것이 아닙니다.
동일한 컬럼인데 로우가 90일때 36개일때 하나일때가 다르다는 얘기입니다.
아래 답변에서 전체에대한 건수 제한은 없다고 하셨으니 답변주신 내용으로는 정확한 원인을 파악할수가 없네요.
전체 소스를 보실수 없으니 아무래도 문제 해결에 한계가 있는듯 하네요...
애써 주셔서 감사합니다.
>데이터셋의 사이즈 제한이 있음을 참고하시기 바랍니다.
>
>데이터셋 전체에 대한 건수 제한은 없으나(컬럼수 제한 없음, 로우수 제한 없음), 데이터 사이즈에 제약이 있습니다.
>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); 이런식으로 변경했는데도 마찬가지네요.
>>>>데이터가 잘리지 않도록 하는 방법이 없을까요?
>>>
>>
>