ADO使用Execute插入CLOB

学习ADO的使用,在过程中,对于向数据库中插入一条CLOB的数据(一本小说),进行了一些尝试:
首先参考像ODBC中的方法,使用open函数打开文本,然后依次读取文本内容,并将内容拼接成一个完整的sql语句。

初始代码如下:

CString SQL = "insert into test_big(id,big) values(18,'";
	int h_file = _open("D:\\test_txt\\big_out.txt", O_BINARY | O_CREAT | O_RDWR, _S_IWRITE);
	int cbRead = 0;
	USES_CONVERSION;
	char Data[4000] = { 0 };
	do {
		cbRead = _read(h_file, Data, 4000);
		if (cbRead <= 0)break;
		SQL += A2T(Data);//类型转换
		memset(Data,0, 4000);
	} while (1);
	SQL += "');";
	m_pConnection->Execute((LPCTSTR)_bstr_t(SQL),&idr,adOptionUnspecified);
	m_pConnection->Close();

在测试过程中,刚开始测试,发现函数在执行sql时报错,猜测可能是因为字符串长度过长,于是将文本内容截取一部分进行测试,发现第二个问题,在每个设置的字符缓冲区后面都会有一部分的乱码,查看代码也用了memset进行重置,可为什么会乱码呢?

最后发现了一个原因,在字符串读取到字符数组后,没有在’\0’作为结束标志,程序就有可能读取到了错误的内存,造成了乱码。

于是修改代码,每次在读取后加上结束符:

	do {
		cbRead = _read(h_file, Data, 3999);
		if (cbRead <= 0)break;
		Data[3999] = '\0';
		SQL += A2T(Data);
		memset(Data,0, 4000);
	} while (1);

此时可以正常保存内容,没有乱码了。

于是再次尝试将整个文本数据进行保存,再次在Execute处保存,于是在管理工具中进行测试,将所有内容复制到sql中进行执行,发现错误,进行排查发现是因为文本中存在英文符号的单引号,',此符号导致sql语句在格式上出现错误,于是将所有的英文单引号进行替换,再次执行即通过。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值