如何使用 oledb 使用其各自的 .dbc 文件从 .dbf 文件中读取/写入数据
How do you read/write data from a .dbf file using its respective .dbc file using oledb?
我被指示用C ++制作一个测试程序,该程序能够从Visual fox pro数据库中读取数据。我只得到了文件,我无法从这些文件读取数据。
我在网上找到了一些能够成功打开访问文件的代码,并且我能够更改它,以便它打开我的数据库文件。
我遇到的问题是我可以使用 .dbc 文件获取任何.dbf文件的列信息,但是当我尝试对存储在行中的数据使用 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 Errorn");
return 1;
}
if (ss.Open(ds)) {
printf("CSession Errorn");
return 1;
}
if (rs.Open(ss, _T("Select * From AppReg01.dbf"))) {
printf("CCommand Errorn");
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 = %dn", 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 Errorn");
return 1;
}
if (ss.Open(ds)) {
printf("CSession Errorn");
return 1;
}
if (rs.Open(ss, _T("Select * From Customers"))) {
printf("CCommand Errorn");
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 = %dn", 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;
}
相关文章:
- .cpp和.h文件中的模板专用化声明
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 文本文件中的单词链表
- CMake-按正确顺序将项目与C运行时对象文件链接
- 使用新行和不使用新行读取文件
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 挂起和取消挂起一个文件DLL
- 如何确定我已使用非编码文件到达 EOF?
- 命名空间中具有.h和.cpp文件的类
- 如何使用ndk-build.cmd构建Android.so文件
- 从包含m行的文件中提取n行,必要时(惰性地)重复该文件
- 读取文件并输入到矢量中
- 在C++中查找文件
- c++库的公共头文件中应该包含什么
- 用c++从输入文件中读取另一行
- Cppcheck生成xml转储文件
- 读取文件的最后一行并输入到链接列表时出错
- 无法编译 rtmidi 测试 cmidiin.cpp 文件, 非法指令
- DBF 文件并行读取
- 如何使用 oledb 使用其各自的 .dbc 文件从 .dbf 文件中读取/写入数据