第一步:配置ODBC。

①、在控制面板找到ODBC,或者在控制面板上搜索ODBC。如图:

②、点击ODBC的添加按钮,选择SQL Server,这是会出现创建SQL Server的新数据源的对话框,我以phonesql为名建立名称,选择SQL登陆的服务器,再点击下一步,选择登陆方式:网络登陆、用户输入登陆,任选(我选择用户输入登陆,以:用户名sa  密码123456为例 )。

                      

③、选择数据库test(我在SQL里面建的test),然后一直点下一步。最后点测试数据源。最后显示测试成功。

             

这样ODBC就建立好了,接下来的工作就是连接数据库了。

第二步:建立数据库的表和添加数据。

    CREATE TABLE [dbo].[worker](
[num] [int] NOT NULL,
[name] [char](20) NOT NULL,
[sex] [char](10) NOT NULL,
[age] [int] NOT NULL,
[shenfennum] [char](20) NOT NULL,
[xueli] [char](10) NOT NULL,
[mianmao] [char](10) NOT NULL,
[mima] [char](20) NOT NULL,
[quanxian] [char](10) NOT NULL,
[born] [char](20) NOT NULL
) ON [PRIMARY]

第三步:使用VC++访问数据库。
①、引用头文件
#include<stdio.h>
#include<windows.h>
#include<sql.h>
#include<sqlext.h>
#include<sqltypes.h>

  解释:1.   SQLINTEGER   定义一个整型变量,相当于C语言中的int。

       2.  SQLCHAR      定义一个字符变量,相当于C语言中的char.
3. ret=SQLConnect(hdbc,(SQLCHAR*)"phonesql",SQL_NTS,(SQLCHAR*)"sa",SQL_NTS,(SQLCHAR*)"",SQL_NTS);//连接数据库
                               phonesql是建立的odbc的数据源,sa是用户名,123456是密码
代码如下:
#include<stdio.h>
#include<windows.h>
#include<sql.h>
#include<sqlext.h>
#include<sqltypes.h>
#include<string.h>
SQLINTEGER num1,age1;
SQLCHAR name1[20],sex1[10],shenfennum1[20],xueli1[10],mianmao1[10],mima1[20],quanxian1[10],born1[20];
SQLINTEGER len_num1,len_name1,len_sex1,len_shenfennum1,len_xueli1,len_age1,len_mianmao1,len_born1,len_mima1,len_quanxian1;
void fuzhi()
{
SQLRETURN ret;
SQLHENV henv;//SQLHANDLE henv
SQLHDBC hdbc;//SQLHANDLE hdbc
SQLHSTMT hstmt;//SQLHANDLE hstmt
ret=SQLAllocHandle(SQL_HANDLE_ENV,NULL,&henv);//申请环境句柄
ret=SQLSetEnvAttr(henv,SQL_ATTR_ODBC_VERSION,(SQLPOINTER)SQL_OV_ODBC3,SQL_IS_INTEGER);//设置环境属性
ret=SQLAllocHandle(SQL_HANDLE_DBC,henv,&hdbc);//申请数据库连接句柄
ret=SQLConnect(hdbc,(SQLCHAR*)"phonesql",SQL_NTS,(SQLCHAR*)"sa",SQL_NTS,(SQLCHAR*)"123456",SQL_NTS);//连接数据库
if(ret==SQL_SUCCESS || ret==SQL_SUCCESS_WITH_INFO){
ret=SQLAllocHandle(SQL_HANDLE_STMT,hdbc,&hstmt);//申请SQL语句句柄
SQLCHAR sql[]="SELECT *FROM worker";
ret=SQLExecDirect(hstmt,sql,SQL_NTS);//直接执行SQL语句
if(ret==SQL_SUCCESS || ret==SQL_SUCCESS_WITH_INFO){
int i=0;
while(SQLFetch(hstmt)!=SQL_NO_DATA){//遍历结果集
/*****************************************数据库整型赋值*******************************/
SQLGetData(hstmt,1,SQL_C_ULONG,&num1,0,&len_num1);
/************************************************************************************/
SQLGetData(hstmt,2,SQL_C_CHAR,name1,20,&len_name1);
SQLGetData(hstmt,3,SQL_C_CHAR,sex1,10,&len_sex1);
SQLGetData(hstmt,4,SQL_C_ULONG,&age1,0,&len_age1);
SQLGetData(hstmt,5,SQL_C_CHAR,shenfennum1,20,&len_shenfennum1);
SQLGetData(hstmt,6,SQL_C_CHAR,xueli1,10,&len_xueli1);
SQLGetData(hstmt,7,SQL_C_CHAR,mianmao1,10,&len_mianmao1);
SQLGetData(hstmt,8,SQL_C_CHAR,mima1,20,&len_mima1);
SQLGetData(hstmt,9,SQL_C_CHAR,quanxian1,10,&len_quanxian1);
SQLGetData(hstmt,10,SQL_C_CHAR,born1,10,&len_born1);
printf("%d %s %s %d %s %s %s %s %s %s\n",num1,name1,sex1,age1,shenfennum1,xueli1,mianmao1,mima1,quanxian1,born1);
}
SQLSMALLINT number_column;
ret=SQLNumResultCols(hstmt,&number_column);//查询结果集列数
if(ret==SQL_SUCCESS || ret==SQL_SUCCESS_WITH_INFO)
printf("结果集共有%d列\n",number_column);
else printf("查询结果集列数失败!\n");
SQLINTEGER number_row;
ret=SQLRowCount(hstmt,&number_row);//查询被影响的行数
if(ret==SQL_SUCCESS || ret==SQL_SUCCESS_WITH_INFO)
printf("结果集共有%d个记录\n",number_row);
else printf("查询结果集记录个数失败!\n"); SQLFreeHandle(SQL_HANDLE_STMT,hstmt);//释放语句句柄
}else printf("查询数据库操作失败!\n"); SQLDisconnect(hdbc);//断开与数据库的连接
}
else printf("连接数据库失败!\n");
SQLFreeHandle(SQL_HANDLE_DBC,hdbc);//释放连接句柄
SQLFreeHandle(SQL_HANDLE_ENV,henv);//释放环境句柄
} /********************************************************/
int main(){
fuzhi(); return 0;
}
第四步:把获取的数据赋值给C语言中结构体中,使操作数据更方便(也可以直接用通过ODBC更改数据,个人觉得麻烦)。
①、定义结构体。
struct worker
{
int num;//工号
char name[20];//姓名
char sex[10];//性别
int age;//年龄
char shenfennum[20];//身份证号码
char xueli[10];//学历
char mianmao[10];//政治面貌
char mima[20];//密码
char quanxian[10];//权限设置
char born[20];//出生年月日
}gong[1000];

  ②、赋值。

                gong[i].num=num1;
gong[i].age=age1;
strcpy((char *)gong[i].name,(char *)name1);
strcpy((char *)gong[i].sex,(char *)sex1);
strcpy((char *)gong[i].shenfennum,(char *)shenfennum1);
strcpy((char *)gong[i].xueli,(char *)xueli1);
strcpy((char *)gong[i].mianmao,(char *)mianmao1);
strcpy((char *)gong[i].mima,(char *)mima1);
strcpy((char *)gong[i].quanxian,(char *)quanxian1);
strcpy((char *)gong[i].born,(char *)born1);

  注意:SQL里面char数据类型是当填写内容不足自身长度时,后面补足相应的空格。所以赋值时,也会把空格符号赋值给变量里面,导致后期处理数据有误。在SQL建表时:将char类型修改为Varchar类型,也可以写一个函数来去除多余的空格符。代码如下:

void trim(char *str)
{
int i,j,k;
char tmpstr[MAXSTRSIZE]; //可以动态分配一下,这里用静态的一般情况可以满足
i=strlen(str);
for(k=j=0;j<i;j++)
{
if(str[j]!=' ')
{
tmpstr[k]=str[j];k++;}
}
tmpstr[k]='\0';
strcpy(str,tmpstr);
}

  整体代码如下:

#include<stdio.h>
#include<windows.h>
#include<sql.h>
#include<sqlext.h>
#include<sqltypes.h>
#include<string.h>
#define MAXSTRSIZE 1024
SQLINTEGER num1,age1;
SQLCHAR name1[20],sex1[10],shenfennum1[20],xueli1[10],mianmao1[10],mima1[20],quanxian1[10],born1[20];
SQLINTEGER len_num1,len_name1,len_sex1,len_shenfennum1,len_xueli1,len_age1,len_mianmao1,len_born1,len_mima1,len_quanxian1;
struct worker
{
int num;//工号
char name[20];//姓名
char sex[10];//性别
int age;//年龄
char shenfennum[20];//身份证号码
char xueli[10];//学历
char mianmao[10];//政治面貌
char mima[20];//密码
char quanxian[10];//权限设置
char born[20];//出生年月日
}gong[1000];
void trim(char *str);
void fuzhi()
{
SQLRETURN ret;
SQLHENV henv;//SQLHANDLE henv
SQLHDBC hdbc;//SQLHANDLE hdbc
SQLHSTMT hstmt;//SQLHANDLE hstmt
ret=SQLAllocHandle(SQL_HANDLE_ENV,NULL,&henv);//申请环境句柄
ret=SQLSetEnvAttr(henv,SQL_ATTR_ODBC_VERSION,(SQLPOINTER)SQL_OV_ODBC3,SQL_IS_INTEGER);//设置环境属性
ret=SQLAllocHandle(SQL_HANDLE_DBC,henv,&hdbc);//申请数据库连接句柄
ret=SQLConnect(hdbc,(SQLCHAR*)"phonesql",SQL_NTS,(SQLCHAR*)"sa",SQL_NTS,(SQLCHAR*)"123456",SQL_NTS);//连接数据库
if(ret==SQL_SUCCESS || ret==SQL_SUCCESS_WITH_INFO){
ret=SQLAllocHandle(SQL_HANDLE_STMT,hdbc,&hstmt);//申请SQL语句句柄
SQLCHAR sql[]="SELECT *FROM worker";
ret=SQLExecDirect(hstmt,sql,SQL_NTS);//直接执行SQL语句
if(ret==SQL_SUCCESS || ret==SQL_SUCCESS_WITH_INFO){
int i=0;
while(SQLFetch(hstmt)!=SQL_NO_DATA){//遍历结果集
/*****************************************数据库整型赋值*******************************/
SQLGetData(hstmt,1,SQL_C_ULONG,&num1,0,&len_num1);
/************************************************************************************/
SQLGetData(hstmt,2,SQL_C_CHAR,name1,20,&len_name1);
SQLGetData(hstmt,3,SQL_C_CHAR,sex1,10,&len_sex1);
SQLGetData(hstmt,4,SQL_C_ULONG,&age1,0,&len_age1);
SQLGetData(hstmt,5,SQL_C_CHAR,shenfennum1,20,&len_shenfennum1);
SQLGetData(hstmt,6,SQL_C_CHAR,xueli1,10,&len_xueli1);
SQLGetData(hstmt,7,SQL_C_CHAR,mianmao1,10,&len_mianmao1);
SQLGetData(hstmt,8,SQL_C_CHAR,mima1,20,&len_mima1);
SQLGetData(hstmt,9,SQL_C_CHAR,quanxian1,10,&len_quanxian1);
SQLGetData(hstmt,10,SQL_C_CHAR,born1,10,&len_born1); gong[i].num=num1;
gong[i].age=age1;
strcpy((char *)gong[i].name,(char *)name1);
strcpy((char *)gong[i].sex,(char *)sex1);
strcpy((char *)gong[i].shenfennum,(char *)shenfennum1);
strcpy((char *)gong[i].xueli,(char *)xueli1);
strcpy((char *)gong[i].mianmao,(char *)mianmao1);
strcpy((char *)gong[i].mima,(char *)mima1);
strcpy((char *)gong[i].quanxian,(char *)quanxian1);
strcpy((char *)gong[i].born,(char *)born1);
trim(gong[i].name);//删除数据库赋值给字符串中的空格字符
trim(gong[i].sex);
trim(gong[i].shenfennum);
trim(gong[i].xueli);
trim(gong[i].mianmao);
trim(gong[i].mima);
trim(gong[i].quanxian);
trim(gong[i].born);
printf("\n***********************结构体数据测试第%d个数据*****************************\n",i+1);
printf("\n\n**************************************************************************\n");
printf(" 工号: %d 姓名: %s 性别: %s 身份证号码: %s \n 学历: %s",gong[i].num,gong[i].name,gong[i].sex,gong[i].shenfennum,gong[i].xueli);
printf("政治面貌: %s 密码%s , 权限:%s 出生年月%s",gong[i].mianmao,gong[i].mima,gong[i].quanxian,gong[i].born);
printf("年纪:%d岁 \n\n",gong[i].age);
printf("**************************************************************************\n");
i++;
}
SQLSMALLINT number_column;
ret=SQLNumResultCols(hstmt,&number_column);//查询结果集列数
if(ret==SQL_SUCCESS || ret==SQL_SUCCESS_WITH_INFO)
printf("结果集共有%d列\n",number_column);
else printf("查询结果集列数失败!\n"); SQLINTEGER number_row;
ret=SQLRowCount(hstmt,&number_row);//查询被影响的行数
if(ret==SQL_SUCCESS || ret==SQL_SUCCESS_WITH_INFO)
printf("结果集共有%d个记录\n",number_row);
else printf("查询结果集记录个数失败!\n"); SQLFreeHandle(SQL_HANDLE_STMT,hstmt);//释放语句句柄
}else printf("查询数据库操作失败!\n"); SQLDisconnect(hdbc);//断开与数据库的连接
}
else printf("连接数据库失败!\n");
SQLFreeHandle(SQL_HANDLE_DBC,hdbc);//释放连接句柄
SQLFreeHandle(SQL_HANDLE_ENV,henv);//释放环境句柄
}
void trim(char *str)
{
int i,j,k;
char tmpstr[MAXSTRSIZE]; //可以动态分配一下,这里用静态的一般情况可以满足
i=strlen(str);
for(k=j=0;j<i;j++)
{
if(str[j]!=' ')
{
tmpstr[k]=str[j];k++;}
}
tmpstr[k]='\0';
strcpy(str,tmpstr);
}
/********************************************************/
int main(){
fuzhi(); return 0;
}

  

  显示结果如下:

C语言+ODBC+SQL 连接的更多相关文章

  1. C语言+ODBC+SQL 操作(向SQL里面添加数据)

    为了节省时间,我就引用上一节的数据库的表和C语言的结构体数组,在结构体数组中添加数据,清空数据库数据. 第一步查询:SQLBindParameter函数的用法. SQLRETURN SQLBindPa ...

  2. 连接SQLServer2005失败--[Microsoft][ODBC SQL Server Driver][DBNETLIB]一般性网络错误。请检查网络文档

    连接SQLServer2005失败,错误信息: 错误类型:Microsoft OLE DB Provider for ODBC Drivers (0x80004005)[Microsoft][ODBC ...

  3. firedac odbc sql server driver连接占线导致另一个hstmt

    firedac odbc sql server driver连接占线导致另一个hstmt 原因:FDQuery.FetchOptions.Mode=fmOnDemand.好像是为了性能问题,不设置则默 ...

  4. 细聊Oracle通过ODBC数据源连接SQL Server数据库

    类似文章搜索引擎上有很多,内容大致相同,今天所谓细聊是因为我在借鉴这些文章时候走了些弯路,所以写此文,为自己备忘,同时如果能为初涉此处知识点的小伙伴提供些帮助就更好了,文章结尾处的一些扩展有一定实战意 ...

  5. MSSQL Server数据库的四种连接方法和sql连接字符串

    MSSQL Server数据库的四种连接方法和sql连接字符串 分类: [ 03 ] C#(131) [ 07 ] SQL Server(68) [ 01 ] .NET(189) 今天用SQL Ser ...

  6. PowerDesigner反向数据库时遇到[Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句。SQLSTATE = 37错误解决方法

    逆向工程中,有时会出现如下错误 ... [Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句 SQLSTATE = 37000 解决方案: 1. ...

  7. [Oracle][ODBC SQL Server Driver][SQL Server]对象名 'RECOVER.HS_TRANSACTION_LOG' 无效(转)

    原帖由 qingyun 于 2010-6-21 15:44 发表 在写pl/sql的时候,有个很重要的注意点:比如:begin  update  某个sqlserver的表@dblink名字 .... ...

  8. 不安装Oracle客户端使用PL/SQL连接服务器端Oracle

    从10G开始,Oracle 提供了一个较为轻量级的客户包,叫做Instant Client Package. 将它安装好后,就不用再安装庞大的Oracle客户端,可以直接通过使用PL/SQL连接服务器 ...

  9. [Microsoft][ODBC SQL Server Driver][DBNETLIB]SQL Server 不存在或访问被拒绝

    一般连接sql数据库,IP_connstr="driver={SQL Server}; server=127.0.0.1;database=数据库名字;uid=sa;pwd=密码" ...

随机推荐

  1. JS调试工具

    IE http://msdn.microsoft.com/zh-cn/library/ie/dn255003(v=vs.85).aspx FF http://www.wumii.com/item/1g ...

  2. Java WeakHashMap 源码解析

    前面把基于特定数据结构的Map介绍完了,它们分别利用了相应数据结构的特点来实现特殊的目的,像HashMap利用哈希表的快速插入.查找实现O(1)的增删改查,TreeMap则利用了红黑树来保证key的有 ...

  3. jQuery中bind,live,delegate与one方法的用法及区别解析

    bind( )方法用于将一个处理程序附加到每个匹配元素的事件上并返回jQuery对象. .bind(eventType[, evnetData], Handler(eventObject)) 其中,参 ...

  4. 如何安装Windows 8系统中的telnet组件

    知识点分析:Window 8 系统中Telnet没有默认安装,成为了一个可选组件,“启用或关闭Windows功能”下即可添加此组件. 操作步骤:1.系统桌面下同时按住键盘上 “Windows” 和“X ...

  5. linux下ssh使用和配置

    常用格式:ssh [-l login_name] [-p port] [user@]hostname 更详细的可以用ssh -h查看. 举例 不指定用户: ssh 192.168.0.11 指定用户: ...

  6. Windows 如何在cmd命令行中查看、修改、删除与添加环境变量

    转自:http://www.cnblogs.com/saptechnique/archive/2013/02/17/2914222.html 首先明确一点: 所有的在cmd命令行下对环境变量的修改只对 ...

  7. Java并发编程:Future接口、FutureTask类

    在前面的文章中我们讲述了创建线程的2种方式,一种是直接继承Thread,另外一种就是实现Runnable接口. 这2种方式都有一个缺陷就是:在执行完任务之后无法获取执行结果. 如果需要获取执行结果,就 ...

  8. SuppressWarnings的警告

    简介:java.lang.SuppressWarnings是J2SE 5.0中标准的Annotation之一.可以标注在类.字段.方法.参数.构造方法,以及局部变量上.作用:告诉编译器忽略指定的警告, ...

  9. homebrew介绍

    对于一个习惯了在 Ubuntu 的终端上通过 apt-get 来安装工具软件的我来说,也希望在Mac上找到类似的工具,能很方便的一条命令就能安装所需的软件,而不用手工的去查找下载编译,或者是折腾安装所 ...

  10. 安装VS2012 update3提示缺少Microsoft根证书颁发机构2010或2011的解决方法

    警告提示如图: (copy的百度贴吧的童鞋的截图) 解决方法: 下载2010.10或2011.10的根证书即可 直通车:http://maxsky.ys168.com/ ——05.||浮云文件||—— ...