C++Builder Programming Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
C++빌더 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
컴포넌트/라이브러리
메신저 프로젝트
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C++빌더 Q&A
C++Builder Programming Q&A
[7381] Re:ADOQuery를 가지고 Update를 할 때에...
원영준 [yjwon88] 2028 읽음    2001-05-11 11:39
이정득 님이 쓰신 글 :
: 안녕하십니까.
: ADOQuery를 가지고 하나의 필드를 Update하려고 합니다.
:
: ADOConnection1객체를 써서 MDB와 연결을 하구여, 먼저 ADOQuery1이 DBGrid1에
: table1의 내용을 select하여 뿌립니다. 그 다음 DBGrid1에 있는 각 셀들을
: 클릭할 때마다 table1의 조회필드를 1씩 update하려고 합니다.
: 이 update는 ADOQuery2가 하게 됩니다.... ADOQuery2역시 ADOConnection1을
: 통하여 MDB와 연결을 합니다.
: ADOQuery2가 update하는 부분은 아래와 같이 구현하였습니다.
:
:
:
: void __fastcall TForm1::UpdateCount(int rec_no_int, int view_count)
: {
:         AnsiString param1 = IntToStr(view_count);
:         AnsiString param2 = IntToStr(rec_no_int);
:
:         ADOQuery2->Close();
:
:         ADOQuery2->Parameters->ParamByName("조회횟수")->Value = param1;
:         ADOQuery2->Parameters->ParamByName("일련번호")->Value = param2;
:
:         ADOQuery2->Open();
: }
:
:
: 참고로 ADOQuery2의 SQL은
: "update table1 set 조회횟수=:조회횟수 where 일련번호=:일련번호"
: 입니다.
:
: 그런데 실행하면 클릭한 첫번째 데이터만 1이 update되고, 그 다음부터는
: update가 일어나지 않습니다. 물론 컴파일/실행시 에러도 나지 않구여..
: 참고로 처음 실행이되자마자 table1은 ADOQuery1에 의해 열립니다.
: ADOQuery1에서 select하는 테이블과 ADOQuery2에서 update하는 테이블은
: 같은 테이블이구여... ADOQuery2의 Object Inspector안의 내용 중
: ExecuteOptions의 eoAsyncExecute만 true로 해 줬습니다.
:
: 이것땜시... 몇 시간을 헤매고 있는지... ㅜ ㅜ
:



open()이 아니고 ExecSQL()아닌가요 ?

+ -

관련 글 리스트
7295 ADOQuery를 가지고 Update를 할 때에... 이정득 2016 2001/05/09
7381     Re:ADOQuery를 가지고 Update를 할 때에... 원영준 2028 2001/05/11
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.