::: 델파이 Tip&Trick :::

델파이 Tip&Trick 성격에 맞지 않는 광고,비방,질문의 글은 즉시 삭제하며
내용을 복사하여 사용할 경우 반드시 이곳(http://www.howto.pe.kr)을 출처로 명시하여 주세요


Category

  김영대(2003-03-07 21:54:51, Hit : 4571, Vote : 1118
 http://www.howto.pe.kr
 Query.RecordCount = -1

사용하는 DB가 로컬에 있는 XBase계열(DBase, Paradox)의 DB라면 이런 문제가 없지만
원격지의 DataBase이라면 이런 문제가 발생합니다
결론부터 말씀드리면 버그는 아니고 TDataSet의 특징입니다
RecordCount는 로컬에 fetch한 레코드의 개수를 세기 때문입니다

BDE는 data-fetching 메커니즘이 있어서 만약 질의한 레코드 갯수가
많을경우 화면의 DBGrid에 한번에 20 개만 보인다면 화면스크롤시 모래시계가
중간중간에 보일겁니다 (DBGrid가 아니더라도 마찬가지 입니다)
즉 질의를 했다고 해서 자료를 다 가지고 오는것이 아니라 중간중간에
필요한 페이지단위로 가져오는 것입니다

그래서 RecordCount가 -1 이라는건 모든 자료를 fetch 하지 않아서 그렇습니다
이때는 강제로 fetch하게 하는 방법이 있는데 간단히 아래처럼
  Query.Open;
  Query.Last;
  Query.First;
하시면 됩니다. Last를 하려면 별 수 없시 다 가져와야 겠죠...
하지만 레코드가 너무 많아 메모리를 잠식하면 out of  virtual memory error를 만날 수 있습니다

그러므로 단지 레코드 갯수만 알아내려면
  SELECT COUNT(*)
  FROM 테이블
해서 갯수만 질의해 오는것이 트래픽 문제를 줄일 수 있습니다

Note:
  Use RecordCount with care, because record counting can be a costly
  operation, especially for SQL queries that return large result sets.
  Generally, an application should only use RecordCount with Paradox and
  dBASE tables.






651   [일반/컴포넌트] ListBox, ComboBox에 근접검색 하기  김영대 2003/03/07 5224 1560
650   [일반/컴포넌트] StringGrid의 중간에 제목 Cell 두기  김영대 2003/03/07 5261 1328
649   [데이터베이스] 몇가지 BDE 환경정보 구하기  김영대 2003/03/07 4184 1110
648   [일반/컴포넌트] 수직 스크롤이 맨마지막으로 이동했는지 검사  김영대 2003/03/07 3776 1103
  [데이터베이스] Query.RecordCount = -1  김영대 2003/03/07 4571 1118
646   [일반/컴포넌트] Bitmap(BMP) 크기를 변경(Stretch)하여 저장하기  김영대 2003/03/07 4724 1235
645   [일반/컴포넌트] 모든 드라이브,디렉토리 검색하여 파일 찾기  김영대 2003/03/07 4485 1120
644   [네트웍/인터넷] NT 네트워크 환경의 컴퓨터 리스트 구하기  김영대 2003/03/07 6787 1694
643   [윈도우즈 API] 윈도우즈에 프로그램으로 폰트 등록하기  김영대 2003/03/07 5243 1430
642   [일반/컴포넌트] TEdit 입력이 최대 길이를 벋어나면 focus 이동  김영대 2003/03/07 4222 1079
641   [데이터베이스] dBase 테이블의 삭제된 레코드 보기  김영대 2003/03/07 3916 1058
640   [윈도우즈 API] 윈도우즈 "시작" 메뉴의 그림 바꾸기  김영대 2003/03/07 4191 1155
639   [윈도우즈 API] 원도우 이동시 다시 그리기 설정/해제  김영대 2003/03/07 4323 1164
638   [윈도우즈 API] Windows error beep 켜기/끄기  김영대 2003/03/07 4419 1260
637   [일반/컴포넌트] 투명한(Transparent) TPanel 콤포넌트  김영대 2003/03/07 4819 1131
636   [데이터베이스] 테이블,인덱스 복사하기  김영대 2003/03/07 3850 1080
635   [일반/컴포넌트] TRichEdit 에 윗첨자, 아랫첨자 만들기  김영대 2003/03/07 4292 1118
634   [윈도우즈 API] 외부 프로그램의 크기를 내 프로그램에서 변경하기  김영대 2003/03/07 4377 1154
633   [윈도우즈 API] Ctrl-Esc, Ctrl-Alt-Del, Alt-Tab 입력 막기  김영대 2003/03/07 5418 1222
632   [일반/컴포넌트] 달력에 그림이나 기호 그리기  김영대 2003/03/07 4184 996
631   [윈도우즈 API] 파일의 이동,복사,삭제 API  김영대 2003/03/07 6322 1527
630   [일반/컴포넌트] TPanel, TImage 에 Gradient 효과 주기  김영대 2003/03/07 4331 1261
629   [시스템] System, User, GDI Resource  김영대 2003/03/07 4559 1331
628   [시스템] PC에 설치된 드라이브 목록 구하기  김영대 2003/03/07 4515 1108
627   [윈도우즈 API] PrintScreen(PrtSc)키의 동작 막기  김영대 2003/03/07 5690 1276
626   [시스템] 플로피(floppy) 디스크 드라이브의 타입 구하기  김영대 2003/03/07 5815 1526
625   [일반/컴포넌트] 문자열 프로시저명으로 실제 프로시저 호출하기  김영대 2003/03/07 4841 1533
624   [일반/컴포넌트] StringGrid 수직 스크롤바의 크기를 임의로 바꾸기  김영대 2003/03/07 4234 1062
623   [일반/컴포넌트] JPEG, Bitmap 상호 변환하여 파일로 저장하기  김영대 2003/03/07 4169 1206
622   [일반/컴포넌트] Access Violation at address ?????? 로부터 소스위치 알기  김영대 2003/03/07 6299 1279
621   [일반/컴포넌트] 각도에 따라 회전한 화살표 그리기  김영대 2003/03/07 4229 1082
620   [윈도우즈 API] 작업표시줄의 "항상 위" 검사하여 설정하기  김영대 2003/03/07 4595 1178
619   [윈도우즈 API] 윈도우즈 탐색기에서 "Copy" 될 파일목록 구하기  김영대 2003/03/07 4847 1284
618   [일반/컴포넌트] TStringGrid의 마우스가 있는 Cell의 Hint 표시  김영대 2003/03/07 6399 1667
617   [윈도우즈 API] 윈도우즈 "시작" 메뉴 표시하기/감추기  김영대 2003/03/07 4341 1153
616   [일반/컴포넌트] ListBox의 Item을 버튼으로 계속 삭제하기  김영대 2003/03/07 3922 1082
615   [윈도우즈 API] 윈도우즈의 주소록(WAB) 프로그램 띄우기  김영대 2003/03/07 5306 1712
614   [윈도우즈 API] 다른 프로그램의 구동 디렉토리 알아내기  김영대 2003/03/07 4758 1285
613   [윈도우즈 API] 윈도우즈 전화걸기 화면 띄우기  김영대 2003/03/07 4465 1195
612   [일반/컴포넌트] RichEdit에서 HTML 태그를 다른색으로 표시하기  김영대 2003/03/07 5322 1190

[1][2][3][4][5][6][7][8] 9 [10]..[25] [다음 10개]
 

Copyright 1999-2019 Zeroboard / skin by zero