이것저것 해본 결과 데이터는 변경이 되는데 필드명이 변경이 안되는것으로 확인 됐습니다..
tmp->Fields->Fields[0]->AsInteger 이런식으로 값을 가져오면 값은 변경이 돼있지만,
field명은 업데이트가 안돼서 tmp->Fields->FieldByName("version")->AsInteger 이런식으로
값을 가져오면 에러가 납니다..
왜 처음에는 필드명을 자동으로 가져오고 그 이후에는 가져왔던 필드명을 그대로 사용하는것일지가 의문입니다..
소두진 님이 쓰신 글 :
:
: TADODataSet *tmp = new TADODataSet(this);
: tmp->Connection = altiCon;
: tmp->CommandText = "SELECT COUNT(*) FROM Manager_Config";
: tmp->Open();
:
: tmp->Fields->Clear();
: tmp->Close();
: tmp->CommandText = "SELECT * FROM Manager_config";
: tmp->Open();
: while (!tmp->Eof) {
: int a = tmp->FieldByName("version")->AsInteger;
: tmp->Next();
: }
:
: tmp->Close();
: delete tmp;
:
:
: 위와 같은 코드에서 두번째 Open 이후에도 첫번째로 select 한 값이 계속 남아있는것 같습니다.
: ( version 필드를 찾을 수 없다는 메세지가 뜨고, GetFieldNames 함수를 날려보면 COUNT 가 있는것으로 보아 이전 값을 갖고있는 것 같습니다 )
:
: TADODataSet 에서 이전에 갖고있던 데이타를 리프레시하려면 어떻게 해야하는지 궁금합니다..
: 감사합니다.
|