QT数据库的使用(QSQLITE) (二 一些坑)
1.对于DB的初始化,一般会先判断路径是否存在,不存在则创建新的路径以及DB,如下:
QDate date = QDate::currentDate(); //获取日期
QString strDate = date.toString("yyyy-MM-dd");
QString driverName = mainWin->driverName;
dirPath = QObject::tr("%1/UserDB/%2").arg(mainWin->StrDir).arg(strDate); //目录
nmDatabase = QObject::tr("%1/%2.db").arg(dirPath).arg(driverName);
/**
* @brief UserDB::loadUserData
* @return
* 初始化测试结果数据库信息 有 连接 无 创建
*/
int UserDB::loadUserData()
{
QDir dir;
bool is;
is = dir.exists(dirPath); //判断目录是否存在
if(!is)
{ //目录不存在
is = dir.mkpath(dirPath); //创建目录
}
QFileInfo fi(nmDatabase); //创建文件
is = fi.isFile(); //是文件 返回true 不是返回false
// is = fi.exists(); //是文件 返回true 不是返回false
qDebug() << fi.baseName() <<"nmDatabase:"<<nmDatabase <<" is file :" << is;
if(!is) //不是文件 则需要新建表
{
createTestResultTable(); //建表
}
db.close();
db.removeDatabase(nmDatabase);
return 1;
}
以上是对路径的判断 , 但是今天在调试时,一直只有第一次才会判断路径错误,后面的就算没初始化,也会判定路径存在,所以使用deBug调试后,发现,在初始化之前确实存在了DB文件,按照步骤来查找,发现我的函数在之前调用了一次nmDatabase连接的数据库查询,
createConnection(nmDatabase); //创建连接
QSqlQuery query(db);
在这里,就算你的DB文件没床架,只要使用了createConnection(nmDataBase),就会给你创建相应的DB文件,所以会在上面路径判断之前就已经创建好了DB文件。
函数的调用步骤,很是重要啊 。。。。。
以上bug可能只是在我的程序中才会出现 ,所以大家知道就好。
QT数据库的使用(QSQLITE) (三 removeDatabase: connection addDatabase: duplicate 解决方法)