【无标题】

该代码示例展示了如何通过ODBC在C++中连接到SQL数据库,并执行SQL查询以从studentinfo.dbo.students表中检索数据。程序首先分配环境和连接句柄,然后设置连接字符串,接着执行SQLConnect和SQLExecDirectW来执行查询。如果查询成功,程序将打印查询结果。
摘要由CSDN通过智能技术生成
#include <stdio.h>    
#include <string.h>    
#include <windows.h>    
#include <sql.h>   
#include <sqlext.h>    
#include <sqltypes.h>    
#include <odbcss.h>
int main()
{
	SQLRETURN ret;
	SQLHENV henv;//环境句柄,获得有关ODBC环境信息
	SQLHDBC hdbc;//连接句柄
	SQLHSTMT hstmt;//SQL语句句柄

	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);//申请数据库连接句柄

	//vc 6.0 使用连接字符串数据类型:SQLCHAR* ,vs 2013 使用:SQLWCHAR*

	SQLWCHAR db[] = L"stud";
	SQLWCHAR user[] = L"stud";
	SQLWCHAR password[] = L"123456";
	//使用SqlServer用户登录,设置访问连接字符串:数据源名称、登录在此数据源的访问账户和密码。

	// SQLWCHAR db[] = L"test_db";
	// SQLWCHAR user[] = L"";
	// SQLWCHAR password[] = L"";//使用Windows集成用户登录,数据源连接字符串的设置方法。

	ret = SQLConnect(hdbc, db, SQL_NTS, user, SQL_NTS, password, SQL_NTS);

	//ret=SQLConnect(hdbc,(SQLWCHAR*)L"pubs",SQL_NTS,(SQLWCHAR*)L"test",SQL_NTS,(SQLWCHAR*)L"123456",SQL_NTS);
	/*test_db为配置的ODBC数据源名称,这里根据自己的配置进行修改*/

	if (!(ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO))
	{
		printf("连接数据库失败!\n");
		return -1;
	}
	else {
		printf("%d连接数据成功!\n", ret);
	}

	ret = SQLAllocHandle(SQL_HANDLE_STMT, hdbc, &hstmt);//获取访问数据库的连接句柄

	/*对连接成功的数据库进行select语句的访问,提取符合查询条件的记录并显示*/
	SQLWCHAR sql2[] = L"select * from studentinfo.dbo.students";
	ret = SQLExecDirectW(hstmt, sql2, SQL_NTS);

	if (!SQL_SUCCEEDED(ret)) {
		printf("Failed to allocate execute statement handle!");
	}//连接失败报错:“获取访问句柄失败”

	if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
	{
		SQLWCHAR str1[20], str2[20], str3[20], str4[20], str5[20];
		SQLINTEGER len_str1, len_str2, len_str3, len_str4, len_str5;
		//SQLLEN len_str1, len_str2, len_str3; 	//	VC 6.0数据类型
		printf("编号\t姓名\t性别\t年龄\t地址\n");

		printf("%d\n", ret);
		SQLFetch(hstmt);
		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("%s\t %s\t %s\t %s\t %s\n", str1, str2, str3, str4, str5);
		}
	}//获取多列记录的返回结果集

	SQLFreeHandle(SQL_HANDLE_DBC, hdbc);//释放连接句柄
	SQLFreeHandle(SQL_HANDLE_ENV, henv);//释放环境句柄
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值