QT插入DATE、BLOB等数据到Oracle

8 篇文章 1 订阅

1.向Oracle数据库表中插入字段类型为DATE的日期数据时,需要通过Oracle自身的函数to_date进行转换,如下:

to_date('2019-02-13 09:07:09','YYYY-MM-DD HH24:MI:SS')

2.获取BOLB字段大小:

dbms_lob.getlength(字段名) FILESIZE

3.向数据类型为BLOB的字段中插入数据,首先需要以二进制的形式读取文件内容。

	QFile file("QtFileBin.cpp");
	file.open(QIODevice::/*ReadWrite*/ReadOnly);
	int len = file.size();
	QByteArray ba = file.readAll();
	QString str = QString(ba.toHex());
	file.close();

**注意:str的长度是实际文件长度的2倍。**实际插入字符串的时候最好直接使用QByteArray 类型。
4.使用QSqlQuery 向数据库中插入数据;

	query.prepare("insert into T_UPDATE_FILE(F_FILENAME,F_UPDATE_PATH,F_FILE_VERSION,F_DATETIME,F_FILE) values (:fileName,:updateP,:version,to_date(:dateTime,'YYYY-MM-DD HH24:MI:SS'),:file)");

	query.bindValue(":fileName", _fileName);
	query.bindValue(":updateP", updatePath);
	query.bindValue(":version", ver);
	query.bindValue(":dateTime", dateTime);
	query.bindValue(":file", fileBA);
	bool b = query.exec();

	if (!b){
		QString err = query.lastError().text();
		QMessageBox::warning(nullptr, QStringLiteral("错误"), err);
	}

运行一下:
在这里插入图片描述
问题:使用占位符错了,:file 修改为其他的,如:fileBlob

	query.prepare("insert into T_UPDATE_FILE(F_FILENAME,F_UPDATE_PATH,F_FILE_VERSION,F_DATETIME,F_FILE) values (:fileName,:updateP,:version,to_date(:dateTime,'YYYY-MM-DD HH24:MI:SS'),:fileBlob)");

	query.bindValue(":fileName", _fileName);
	query.bindValue(":updateP", updatePath);
	query.bindValue(":version", ver);
	query.bindValue(":dateTime", dateTime);
	query.bindValue(":fileBlob", fileBA);
	bool b = query.exec();

	if (!b){
		QString err = query.lastError().text();
		QMessageBox::warning(nullptr, QStringLiteral("错误"), err);
	}

注意:日期时间的绑定方式,直接把oracle的函数to_date放到SQL语句中

insert into T_UPDATE_FILE(F_FILENAME,F_UPDATE_PATH,F_FILE_VERSION,F_DATETIME,F_FILE) values (:fileName,:updateP,:version,to_date(:dateTime,'YYYY-MM-DD HH24:MI:SS'),:fileBlob)
  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wb175208

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值