VS2019配置ODBC连接sql server数据库

C语言连接SQL Server数据库并且完成一次简易操纵

#include <windows.h>
#include <sql.h>
#include <sqlext.h>
#include <sqltypes.h>
#include <odbcss.h>
#include <stdio.h>

SQLHENV henv;//环境句柄
SQLHDBC hdbc;//连接句柄
SQLHSTMT hstmt;//语句句柄
SQLRETURN retcode;//返回值

int main()
{
	retcode = SQLAllocHandle(SQL_HANDLE_ENV, NULL, &henv);//申请环境句柄
	retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, SQL_IS_INTEGER);
	retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc);//申请数据库连接句柄

	retcode = SQLConnect(hdbc, (SQLCHAR*)"test_server32", SQL_NTS, (SQLCHAR*)"sa", SQL_NTS, (SQLCHAR*)"123456", SQL_NTS);
	//“test_server32”是ODBC中添加的数据源名字,"123456"是我设置的sa密码,读者根据自己的设置自行修改
	if (!(retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO))
	{
		printf("连接数据库失败!\n");
		return -1;
	}
	else
	{
		printf("connect SQL success!");
	}
	
	retcode = SQLAllocHandle(SQL_HANDLE_STMT, hdbc, &hstmt);
	SQLCHAR sql1[] = "use english_words";//使用english_words数据库,读者根据自己创建的数据库名称进行修改
	SQLCHAR sql2[] = "select * from Table_english_word";//查询已创建好的StudentInfo表所有列
	retcode = SQLExecDirect(hstmt, sql1, SQL_NTS);//SQLExecDirect,此函数用于执行SQL语句,执行sql1语句,即"use english_words"
	retcode = SQLExecDirect(hstmt, sql2, SQL_NTS);//执行sql2语句
	if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO)
	{
		SQLCHAR str1[50], str2[50], str3[50], str4[50], str5[50];
		SQLINTEGER len_str1, len_str2, len_str3, len_str4, len_str5;
		while (SQLFetch(hstmt) != SQL_NO_DATA)
		{
			SQLGetData(hstmt, 1, SQL_C_CHAR, str1, 50, &len_str1);   //获取第一列数据
			SQLGetData(hstmt, 2, SQL_C_CHAR, str2, 50, &len_str2);   //获取第二列数据
			SQLGetData(hstmt, 3, SQL_C_CHAR, str3, 50, &len_str3);
			//SQLGetData(hstmt, 4, SQL_C_CHAR, str4, 50, &len_str4);
			//SQLGetData(hstmt, 5, SQL_C_CHAR, str5, 50, &len_str5);

			printf("\n%s\t%s\t%s\n", str1, str2, str3);
		}
	}
	printf("processes finish\n");
	SQLFreeHandle(SQL_HANDLE_DBC, hdbc);//释放连接句柄
	SQLFreeHandle(SQL_HANDLE_ENV, henv);//释放环境句柄
	
	return 0;
}

注:
单考虑连接数据库部分 不管VS2019设置为x86 还是x64都需要在项目的属性中改成多字节字符集,然后32位的用x86 64位的用x64 数据库连接后获取数据的部分暂未测试

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值