Qt通过ODBC连接SQL Server2008实践总结
Qt连接数据库的方式很多,这里说明一种最常用也是最实用的方式,因为这种方式在Windows上开发程序使用起来非常方便,并且也是远程连接数据库所需要用到的方式。
前提工作:
在Win7下安装了SQL Server 2008,并在SQL Server中创建了数据库MyDB。
Qt通过ODBC连接SQL Server 2008概述:
Qt通过ODBC连接数据库时,使用的数据库名不是直接写入数据库名称,而是DSN名。
关于DSN的简要介绍:
原名:Data Source Name
中文名:数据源名称
DSN为ODBC定义了一个确定的数据库和必须用到的ODBC驱动程序。每个ODBC驱动程序定义为该驱动程序支持的一个数据库创建DSN需要的信息。就是说安装ODBC驱动程序以及创建一个数据库之后,必须创建一个DSN。
DSN名的使用方式有两种:
1、在操作系统中配置DSN;
2、在Qt程序代码中采用DSN连接字符串直接连接ODBC数据库。
下面详细介绍在操作系统中配置DSN方式下连接SQL Server 2008的操作过程
在操作系统中配置DSN
1、在Win7系统中配置DSN详细图解









2、配置好DSN后就可以在Qt程序中使用此DSN连接数据库了:
其中main.cpp代码如下:
#include <QtGui/QApplication>
#include "dialog.h"#include <QSqlDatabase>#include <QStringList>#include <QDebug>#include <QMessageBox>#include <QtSql>#include <QSqlQuery>int main(int argc, char *argv[]){QApplication a(argc, argv);Dialog w;w.show();QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");qDebug()<<"ODBC driver?"<<db.isValid();QString dsn = QString::fromLocal8Bit("QTDSN");db.setHostName("127.0.0.1");db.setDatabaseName(dsn);db.setUserName("sa");db.setPassword("198811200");if(!db.open()){qDebug()<<db.lastError().text();QMessageBox::critical(0, QObject::tr("Database error"), db.lastError().text());return false;}elseqDebug()<<"database open success!";QSqlQuery query(db);query.exec("select * from student");while(query.next()){//qDebug()<<query.value(0).toString();qDebug()<<query.value(1).toString();//qDebug()<<query.value(2).toString();//qDebug()<<query.value(3).toString();//qDebug()<<" ";}return a.exec();}
测试输出结果:
ODBC driver? true
database open success!
"李四 "
"王五 "
"赵六 "
"吴莉莉 "
"刘晓红 "
"陈丽芬 "
"正如因 "
"zhu "
参考:
http://www.xuebuyuan.com/619048.html
http://hi.baidu.com/hzau_edu/item/091aa61a12b4e98488a956a5
http://blog.163.com/luminary_fan/blog/static/1941080892013069100349/
如果出现错误,请确认如下配置正确:
1、

建议将SQL Server(MYSQLSERVER)、SQL Server(SQLEXPRESS)服务停止,避免冲突。
2、

注意:更改配置后,务必重新启动数据库服务器

Qt通过ODBC连接SQL Server2008实践总结的更多相关文章
- cenos6.5 64位下PHP远程连接sql server2008成功案例
准备工作: 1.sql server2008服务器(开放远程端口,默认为1433,我用的是192.168.1.129) 2.安装好php的centos服务器 步骤: 1.php安装mssql扩展.ce ...
- php5.2 连接 SQL Server2008
如果你见到下面这一段输出的话,那么你有福了!!!! Array ( [0] => Array ( [0] => IMSSP [SQLSTATE] => IMSSP [1] => ...
- Java连接Sql Server2008
参考:http://weistar.iteye.com/blog/1744871 准备工作: 1.下载JDBC驱动包:http://www.microsoft.com/zh-cn/download/d ...
- java 连接sql server2008配置
Java 应用程序连接SQL Server2008 (Eclipse+JDK7.0+jdbc4.0.jar+Sql Server2008) 假设应用端的连接语句为: String url = &quo ...
- linux centos6.4 php连接sql server2008
1.安装SQL Server驱动freetds yum search freetds yum install freetds php-mssql 或者下载编译安装 2.修改/etc/freetds ...
- Unity3D(C#)连接SQL Server2008
首先部署安装sql server2008,添加Sql Manager. Unity3D连接需要在Unity2017\Editor\Data\Mono\lib\mono\unity文件下找到4个头文件l ...
- Apache Doris 通过ODBC连接SQL Server
社区有小伙伴有使用Doris ODBC外表连接SQL Server数据库,使用中遇到不知道驱动怎么安装,苦于我这边也没有SQL Server的环境,正好社区有用户使用了这个数据库,也安装ODBC驱动测 ...
- WAS6.1连接SQL Server2008数据库连接池配置
原文链接:http://www.cnblogs.com/lyr2012/archive/2012/06/13/2547804.html 说明:该步骤只适用与websphere 6.1.0.15之前的版 ...
- linux odbc连接sql server2014
首先坑爹呀!由于配置Zabbix 用到这个,网上资料一顿搜,一顿报错,调各种参数,依然无法连接,我竟无言以对: 这个只是项目的一小部分,只提供成功案例,没做深入研究,可以让遇到的兄弟少走弯路: 建议第 ...
随机推荐
- 教你调用数据库读取短信 记事本 通讯录文件,让ios5的短信恢复到ios4
由于高版本的ios固件向下恢复到低版固件时无法通过itunes恢复备份,所以一些数据,比如SMS需要通过提取文件的方式单独进行备份恢复特别是ios5的短信,之前很是头痛,直接将文件恢复到指定目录修改权 ...
- could not connect to server: Connection refused (0x0000274D/10061)
Oracle Linux 6.8 PostgreSQL Server IP: 192.168.10.220 Windows 7 x64 pgAdmin Custom Port IP: 192.168. ...
- PHPthinking赠书了!
[站长赠书]2014年10月第一期幸运用户 大家好,我是PHP开发学习门户的站长,小站建站一个多月,感谢大家以来的关注和支持,假设大家对本站有什么建议或者投稿,欢迎留言或者给我发邮件. 本站宣布对于 ...
- Redis Nosql数据库
Redis是一个key-value存储系统.和Memcached类似.可是攻克了断电后数据全然丢失的情况.并且她支持很多其它无化的value类型.除了和string外,还支持lis ...
- ViewHolder的标准写法
最标准的写法,就是为每一个AdapterView的子View新建一个对应的ViewHolder,同时声明为prtivate final static.ViewHolder类中定义各种成员变量. pub ...
- [Web 前端 ] Jquery attr()方法 获取或修改 对象的属性值
cp from : https://blog.csdn.net/gf771115/article/details/18086707 jquery中用attr()方法来获取和设置元素属性,attr是at ...
- 安卓之上传文件,即HTTP提交表单
获取文件: public void Init() { noScrollgridview = (GridView) findViewById(R.id.noScrollgridvie ...
- Orchard之在前台显式一个属于自己的列表
一:当前现状 Orchard 并不提供筛选 Owner 的 Query,但是 Gallery 中有提供,那就是:Owner Queries. Install 之,然后在解决方案中引入该 Project ...
- android studio运行时报错AVD Nexus_5X_API_P is already running解决办法
运行刚搭建好的Android环境时会报这种错误: AVD Nexus_5X_API_P is already running. If that is not the case, delete the ...
- 【转】Mysql行转换为列
From : http://www.cnblogs.com/lhj588/archive/2012/06/15/2550392.html# 今晚需要统计数据生成简易报表,由原表格数据是单行的形式,最好 ...