Chinaunix首页 | 论坛 | 博客

OS

  • 博客访问: 2306545
  • 博文数量: 691
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 2660
  • 用 户 组: 普通用户
  • 注册时间: 2014-04-05 12:49
个人简介

不浮躁

文章分类

全部博文(691)

文章存档

2019年(1)

2017年(12)

2016年(99)

2015年(207)

2014年(372)

分类: LINUX

2014-11-25 17:33:42

1、创建程序后提示“QSqlDatabase: No such file or directory” 的错误

2、大部分的实例中直接通过在main函数声明QSqlDatabase dbconn=QSqlDatabase::addDatabase("QSQLITE")来添加数据库,创建的QSqlDatabase对象的作用域有问题,即在其他的函数或这类对象中使用此局部对象的问题, 还有就是在其他非dbconn作用域函数中在debug调试版本中可以通过QSqlQuery得到结果,但是在非debug调试版本中无法获取到结果

3、在使用QSqlQuery的时候直接通过如下方式使用

  1. {  
  2. .....  
  3.     QSqlQuery query;  
  4.     query.exec("create table student(id varchar,name varchar)");   
  5. .....  
  6. }  

首先说明这条语句可以执行的前提是在同一个函数中(前面示例中为main函数),且声明的QSqlDatabase对象在同一个作用域中;

如果在其他非QSqlDatabase对象的函数或作用域中的时候在debug的调试状态下可以得到QSqlQuery 的执行结果,但是在非debug调试状态下将得不到所要的结果(如通过QSqlQuery 执行select语句)

4、使用QSqlQuery  没有任何参数的对象,运行exec函数的时候如何查找我要执行那个数据库的sql语句?

 

针对以上的问题,可以有以下的解决方法

1、可以通过在工程的pro文件添加QT += sql 使工程(或lib)支持数据库的操作

2、可以通过如下代码方式创建一个QSqlDatabase的指针,然后将指针保存在类中,这样就可以解决作用域的问题,

  1. QSqlDatabase * m_sqliteDB= new QSqlDatabase(QSqlDatabase::addDatabase("QSQLITE""dataSqlite"));  

    为了防止QSqlQuery查询不到结果,最好是创建数据库的时候指定链接名(connectionName),就是上面代码的第二个参数。

3、在使用了2的解决方案后,其实3也就容易解决了,在声明QSqlQuery的时候加上QSqlDatabase 参数,代码如下

  1. QSqlQuery query(*m_sqliteDB);  

其中m_sqliteDB是通过2的方案中创建的指针的解引用。

然后再调用 query的exec函数执行代码即可。

4、当使用3的解决方案后,这时也就不存在说因为在不同的函数中使用QSqlQuery 无参数对象是,直接调用其exec函数的时候迷惑为什么没有说明是使用哪一个数据库的问题了。

阅读(1563) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~