В первой части статьи мы рассмотрели, как использовать CRecordset, порождая от него новые классы. Возникает вопрос: а можно ли использовать этот класс напрямую? Ответ на этот вопрос звучит так: CRecordset может использоваться для доступа к множеству записей, построенному только на основе запроса (а не имени таблицы), и только в режиме read only. Обратиться к значениям конкретных полей в этом случае можно, используя функцию CRecordset::GetFieldValue. Функции CRecordset::Move* используются, как и раньше.
Следующий фрагмент выводит фамилии всех авторов из БД pubs. Так как нам требуется доступ к таблице authors в режиме , мы можем использовать класс CRecordset напрямую.
CRecordset Rs(&Db);
Rs.Open(CRecordset::forwardOnly, "SELECT aau_lname FROM authors");
while (!Rs.IsEOF) {
CString lname;
Rs.GetFieldValue((short)0, lname);
printf ("%s\n", lname);
Rs.MoveNext;
}
Мы уже умеем конструировать объекты класса CRecordset, передавая конструктору указатель на соединение:
CRecordset Rs(&Db);
Существует ещё одна эквивалентная форма создания объекта CRecordset:
CRecordset Rs;
Rs.m_pDatabase = &Db
Зачем она может понадобиться, спросите вы. Дело в том, что система Microsoft IntelliSense, которая услужливо выдаёт вам списки членов класса и параметров функции прямо, очень болезненно реагирует на конструкторы с параметром: в коде, который следует за вызовом такого конструктора, подсказки попросту перестают появляться. Если вы столкнулись с такой проблемой, смело используйте второй вариант конструирования объекта CRecordset.
Любые замечания по форме и содержанию статьи вы можете прислать мне по адресу [email protected].
Q. Есть у меня файлы с расширением .pdb (Microsoft C/C++ program database 2.00) (их MS VC++ делает в папке Debug проекта создаются), можно ли с их помощью восстановить исходники программы (размер у них такой, что туда не только прога влезет, но и комментарии к ней в HTML (FrontPage Style) формате :)