Мне было поручено создать тестовую программу на c ++, которая могла бы считывать данные из базы данных Visual Fox Pro. Мне только дали файлы, и я испытываю затруднения при чтении данных из этих файлов.
Я нашел в сети некоторый код, который смог успешно открыть файлы доступа, и я смог изменить его, чтобы он открывал мои файлы базы данных.
У меня проблема в том, что я могу получить информацию о столбцах любого файла .dbf, используя файл .dbc, но когда я пытаюсь использовать rs.movenext () для данных, хранящихся в строках, данные не отображаются из базы данных файл.
Код в целом работает для доступа к файлам, используя закомментированную строку подключения. По какой-то причине, когда я переключаюсь на файлы .dbf и .dbc, данные строки не могут быть отображены.
Любое понимание было бы замечательно. Мой код ниже.
int _tmain(int argc, _TCHAR* argv[])
{
CoInitialize(NULL);
CDataSource ds;
CSession ss;
CCommand<CDynamicAccessor> rs;
DBTYPE dbt;
int i;if (ds.OpenFromInitializationString(_T("Provider=vfpoledb.1;Data Source=C:\\Users\\xx\\xx\\xx\\appdata.dbc;Collating Sequence=general;"))) {
//if (ds.OpenFromInitializationString(_T("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\\Testdata.mdb"))) {
printf("CDataSource Error\n");
return 1;
}if (ss.Open(ds)) {
printf("CSession Error\n");
return 1;
}
if (rs.Open(ss, _T("Select * From AppReg01.dbf"))) {
printf("CCommand Error\n");
return 1;
}
int count = 0;
for (i = 1; i <= (int)rs.GetColumnCount(); i++) {
rs.GetColumnType(i, &dbt);
printf("Column number = %d, Column name = %S, Column type = %d\n", i, rs.GetColumnName(i), dbt);}while (!rs.MoveNext()) {
printf_s("blah: %S, %S \n \n", rs.GetValue(1), rs.GetValue(2)); \
count++;
}
rs.Close();
ss.Close();
ds.Close();CoUninitialize();
return 0;
}
Мой вывод:
Column number = 1, Column name = kname, Column type = 128
Column number = 2, Column name = lname, Column type = 129
Column number = 3, Column name = key, Column type = 128
Column number = 4, Column name = rtype, Column type = 131
Column number = 5, Column name = type, Column type = 131
Column number = 6, Column name = access, Column type = 131
Column number = 7, Column name = shortvalue, Column type = 128
Column number = 8, Column name = value, Column type = 13
Column number = 9, Column name = props, Column type = 13
Column number = 10, Column name = comment, Column type = 13
blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah:
blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah:
blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah:
blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah:
blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah:
blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah: blah:
Press any key to continue . . .
Разве это не% s, а не% S (не уверен, что мой C ржавый)? Это работает для меня:
int _tmain(int argc, _TCHAR* argv[])
{
CoInitialize(NULL);
CDataSource ds;
CSession ss;
CCommand<CDynamicAccessor> rs;
DBTYPE dbt;
int i;if (ds.OpenFromInitializationString(_T("Provider=vfpoledb;Data Source=C:\\Program Files (x86)\\Microsoft Visual FoxPro 9\\Samples\\Northwind\\northwind.dbc;"))) {
// if (ds.OpenFromInitializationString(_T("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\data\\Northwind.mdb"))) {
printf("CDataSource Error\n");
return 1;
}if (ss.Open(ds)) {
printf("CSession Error\n");
return 1;
}
if (rs.Open(ss, _T("Select * From Customers"))) {
printf("CCommand Error\n");
return 1;
}
int count = 0;
for (i = 1; i <= (int)rs.GetColumnCount(); i++) {
rs.GetColumnType(i, &dbt);
printf("Column number = %d, Column name = %S, Column type = %d\n", i, rs.GetColumnName(i), dbt);}
while (!rs.MoveNext()) {
printf_s("blah: %s, %s \n \n", rs.GetValue(1), rs.GetValue(2) );
count++;
}
rs.Close();
ss.Close();
ds.Close();CoUninitialize();
return 0;
}
Других решений пока нет …