2016-01-14 6 views
0

Ive было поручено сделать тестовую программу на C++, которая способна считывать данные из базы данных visual fox pro. Ive были предоставлены только файлы, и у меня возникли проблемы с чтением данных из этих файлов.Как вы читаете/записываете данные из .dbf-файла, используя его .dbc-файл, используя oledb?

Я нашел код в Интернете, который смог успешно открыть файлы доступа, и я смог изменить его, чтобы он открывал мои файлы базы данных.

Проблема, с которой я сталкиваюсь, заключается в том, что я могу получить информацию о столбцах любого файла .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 . . . 

ответ

1

не было бы% 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; 
} 
+0

Я не могу поверить, что моя проблема была такая маленькая. Спасибо, что прочитали мой код и обнаружили эту небольшую ошибку, она работает сейчас! – Danderson