QT插入DATE、BLOB等数据到Oracle

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);
	}

运行一下:
QT插入DATE、BLOB等数据到Oracle_第1张图片
问题:使用占位符错了,: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)

你可能感兴趣的:(qt,oracle)