电脑技术学习

Sybase批量操作(BCP)的设计和实现

dn001
在类CSYBBCP中,主要是函数BCP_Transfer_db进行数据库大批量数据的导入和导出,要完成数据传输操作,需要如下几个步骤: // 初始化:指定表明和数据文件

if(bcp_init(m_dbproc, tablename, datafile, NULL, direction) == FAIL)

{

return FALSE;

}

// 设置批量操作的控制参数,这里设置的每批记录数

if(bcp_control(m_dbproc, BCPBATCH, (DBINT) 1000) == FAIL)

{

return FALSE;

}

// 设置列数

if(bcp_columns(m_dbproc, cCols) == FAIL)

{

return FALSE;

}

// 设置列格式

for(ii = 1; ii < cCols; ii++)
{
if(bcp_colfmt(m_dbproc, ii, SYBCHAR, 0, -1, (UINT8 *) fldterminator, _strlen(fldterminator), ii) == FAIL)
{
return FALSE;
}
}
if(bcp_colfmt(m_dbproc, ii, SYBCHAR, 0, -1, (UINT8 *) rowterminator, _strlen(rowterminator), ii) == FAIL)
{
return FALSE;
}
// 执行批量操作
while(bcp_exec(m_dbproc, & cRows) == FAIL)
{
return FALSE;
}

// 批量操作结束

retcode=bcp_done(m_dbproc);

在使用Sybase12.5客户端之前,程序未调用bcp_control函数,在执行bcp_exec函数时不是使用while,而是使用if判断,代码如下:

if(bcp_exec(m_dbproc, & cRows) == FAIL)
{
;return FALSE;
}

程序能正常完成功能,当使用Sybase12.5客户端后,在执行时发现程序突然退出,异常处理也未能记录日志,后跟踪发现程序是在执行bcp_exec时退出,但是未能查出原因,咨询Sybase公司技术人员,也没能解决问题。后来在一次测试中偶然发现有时能导入数据,于是测试数据文件在什么情况下能导入,实验其临界点,多次测试后发现文件1000条记录为临界点,超过则出现问题。于是本人在程序中调用bcp_control函数,设置批量记录为1000,如果数据文件记录多于1000,则需要bcp_exec执行多次才能完成,所以采用while,而不是if,这样问题解决。
;
三、结束

在上面的论述中,还仅仅涉及DB LIBRARY,对于Sybase客户端编程,还有CT LIBRARY方式,目前CT已经支持导出,但不支持导入。