gpt4 book ai didi

c++ - 使用 ADO/OLEDB 批量插入/加载

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:53:17 28 4
gpt4 key购买 nike

我在我的 cpp 代码中使用 ADO 访问 OLE DB 服务器..

int main(int argc, char** argv) {
try {
_ConnectionPtr ConnPtr;
ConnPtr.CreateInstance("ADODB.Connection");
ConnPtr.Open("Provider=ASEOLEDB; Data Source=MYSERVER; User ID=MYID; Password=MYPW");


_RecordsetPtr RecPtr;
RecPtr.CreateInstance("ADODB.Recordset");


ReccPtr = Connptr.execute("BULK INSERT ...");
// .................
// ...bulk insert...
// .................


ConnPtr->Close();
}
catch (_com_error &e) {

}
}

我在网上找不到任何关于如何实现批量插入部分的资源。我读过一篇关于使用 Java 批量插入的文章,但我不知道如何在 C++/ADO 中完成这件事。

( http://venzi.wordpress.com/2012/03/31/loading-data-fast-regular-insert-vs-bulk-insert/ )

有人对此主题有建议/资源吗?

最佳答案

BULK INSERT T-SQL 语句从文件导入数据。该文件需要本地存储在 SQL Server 框上或可通过 UNC 路径访问。参见 http://msdn.microsoft.com/en-us/library/ms188365.aspx .

要直接从 native 代码批量插入,您需要使用 IRowsetFasLoad COM 接口(interface)或 ODBC_BCP 函数调用。经典 ADO 没有批量插入方法。如果托管代码是一个选项,您可以使用 SqlClient SqlBulkCopy 类。

关于c++ - 使用 ADO/OLEDB 批量插入/加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24492684/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com