请教Qt for android Sqlite数据库连接问题

Ln_Jan 2016-02-02 02:23:40
用Qt连接Sqlite数据库,在windows下是可以连接的,也能实现数据查询和修改,在调试中的信息如下:

但是在android真机上调试则是这样:

在编译好的android文件夹的libs文件夹中找到qsqlite和sql驱动


在工程的pro文件中也添加了SQL模块,这种情况应该是我驱动已经有了吧?想请问下为什么在android手机中会连接不上数据库?谢谢!
...全文
581 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
human_blue 2016-02-04
  • 打赏
  • 举报
回复
我也来学习下
Ln_Jan 2016-02-03
  • 打赏
  • 举报
回复
问题已经解决了。其实是有数据的。可能是因为gdb版本的关系查看不到。分享点经验给各位,QT的setDatabaseName中可以填写绝对路径跟工程的相对路径。在android平台上项目的根目录为:/data/data/xxxx/files。可以把QSQLITE数据库文件放在工程android/assets目录下,数据库文件会原封不动放在apk安装包的assets文件夹下。再通过QFile读取assets的数据库文件,复制到根目录下即可访问数据库
Ln_Jan 2016-02-02
  • 打赏
  • 举报
回复
引用 3 楼 东莞某某某的回复:
你用QSqlDatabase::drivers()看看有无QSQLITE
有啊。。桌面上有移植到安卓平台上就一定有吗
东莞某某某 2016-02-02
  • 打赏
  • 举报
回复
你用QSqlDatabase::drivers()看看有无QSQLITE
Ln_Jan 2016-02-02
  • 打赏
  • 举报
回复
引用 1 楼 东莞某某某的回复:
楼主你好,尝试一下传入type参数来判断驱动是否正常识别: QSqlDatabase db = QSqlDatabase::addDatabase(type,SESSION_NAME); 如果驱动OK,QSqlDatabase::open()失败的情况下,通过QSqlDatabase::lastError()来查找错误. // sample QSqlDatabase db = QSqlDatabase::addDatabase(type,SESSION_NAME); if( db.isValid() ){ }else{ } db.setHostName(host); db.setPort(port); db.setDatabaseName(dbName); db.setUserName(user); db.setPassword(pwd); bool bOK = db.open(); if( bOK ){ }else{ qDebug() << db.lastError().text(); }
你好。我那段代码就已经传入QSQLITE了。可能被调试信息挡住了,在桌面平台上测试是能看到对象db的值的。但是在我的手机上debug的时候对象db就只能看到no such value了。请问这是什么原因?
东莞某某某 2016-02-02
  • 打赏
  • 举报
回复
楼主你好,尝试一下传入type参数来判断驱动是否正常识别: QSqlDatabase db = QSqlDatabase::addDatabase(type,SESSION_NAME); 如果驱动OK,QSqlDatabase::open()失败的情况下,通过QSqlDatabase::lastError()来查找错误. // sample QSqlDatabase db = QSqlDatabase::addDatabase(type,SESSION_NAME); if( db.isValid() ){ }else{ } db.setHostName(host); db.setPort(port); db.setDatabaseName(dbName); db.setUserName(user); db.setPassword(pwd); bool bOK = db.open(); if( bOK ){ }else{ qDebug() << db.lastError().text(); }

16,216

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧