QT數據庫操作

stivenjia 2011-01-15 03:30:17
問題如下:使用QOCI驅動訪問oracle數據庫,請問如何設置連接、批処理超時屬性。
...全文
171 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
岁小草 2012-07-09
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 的回复:]
只要你编译好了驱动,并且放到了插件目录/数据库驱动目录/下, 其它操作就是统一的
QSqlDatabase db = QSqlDatabase::addDatabase("QOCI");
db.setHostName("192.168.0.1");
db.setDatabaseName("dbname");
db.setUserName("username");
db.s……
[/Quote]我已经将QOCI编译后生成的两个.a文件和两个 .dll放在程序的debug文件夹下发到客户端了,为什么还是报错说没有QOCI驱动。
stivenjia 2011-01-18
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 yangglemu 的回复:]
很遗憾,Oracle客户端没有提供TimeOut功能,.Net能提供Oracle的连接超时,是通过操作系统建立连接池间接实现的
曾看到有人用线程+定时器写过超时功能
去http://www.qtforum.org/看看,
建议用qsqldatabase oarcle connect timeout作关键字用Google只搜英文(中文都是些不相干的东西)
[/Quote]
谢谢哥们,我去找找。
  • 打赏
  • 举报
回复
很遗憾,Oracle客户端没有提供TimeOut功能,.Net能提供Oracle的连接超时,是通过操作系统建立连接池间接实现的
曾看到有人用线程+定时器写过超时功能
去http://www.qtforum.org/看看,
建议用qsqldatabase oarcle connect timeout作关键字用Google只搜英文(中文都是些不相干的东西)
stivenjia 2011-01-17
  • 打赏
  • 举报
回复
这个是建立数据库连接,现在遇到的问题是在和oracle数据库断开网络连接后,需要设置一个等待超出时间,否则exec会处于挂起状态
  • 打赏
  • 举报
回复
只要你编译好了驱动,并且放到了插件目录/数据库驱动目录/下, 其它操作就是统一的
QSqlDatabase db = QSqlDatabase::addDatabase("QOCI");
db.setHostName("192.168.0.1");
db.setDatabaseName("dbname");
db.setUserName("username");
db.setPassword("passwd");
db.setPort(1521);
if (db.open())
printf("ok");
else
printf("sorry");

16,199

社区成员

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

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