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)