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

本文为SQL初学者提供C语言连接SQLServer的详细步骤,包括设置SQLServer验证模式、创建数据库和表、使用ODBC数据源、在Visual Studio中编写C++代码实现数据查询。通过实例代码展示了如何从C++程序读取SQLServer数据库中的数据。
摘要由CSDN通过智能技术生成

本文旨在针对SQL完全小白的朋友,让其了解C语言连接SQL Server的方法,并且完成一个简易操纵(可以是写入/读出/增删查改)。本文使用的是SQL Server 2019,安装教程可参考SqlServer2019安装教程-基本安装_七海桑城-CSDN博客_sqlserver2019安装教程,此外,本文程序设计参考了使用c语言操作sql server数据库_从今以后...-CSDN博客_c语言sql

1.SQL Server安装好后,管理员身份打开 Microsoft SQL Server Management Studio

会弹出以下界面,修改服务器名称,

修改服务器名称为自身电脑的计算机名

2.右键服务器——>属性——>安全性——>服务器身份验证改为SQL和win验证模式,

3.右键sa,选择属性,修改配置

  • 修改成自己想要的密码

  • 登录名改为启用

  • 右键子目录下的数据库,选择新建数据库

  • 创建一个测试用的数据库,名称自拟,我这里是TEXT

  • 重新启动

4.重新启动后,使用SQL Server身份登录

登录名"sa",密码为之前自己设置的密码

  • 右击自己创建的数据库下的“表”,新建表
  • 计划创建一张表,添加内容,利用C语言连接SQL Server,并且获取表格内容

  • 我这里创建了一张名为“Studentlnfo”的表
  • 右方表格中输入自己想要的“列名”以及“数据类型”,我这里是手动创建。也可以通过新建查询的方式,通过输入代码进行表格的创建

  • 右键新建好的表,选择编辑前200行

  • 随意输入一些数据进行测试,最后全部保存

5.在windows搜索功能中打开ODBC Data Sources

  • 在系统DSN下添加数据源,选择SQL Server

  • 名称自拟,服务器名称为SQL Server中的服务器登录名称

  • 选择使用ID和密码的SQL Server验证,登录ID为sa,输入之前设置的密码

然后一直下一步下一步就行

  • 最后数据源被添加,点击确认

6.打开visual studio,建立新项目,源文件新建项添加C++文件

#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*)"mytest", SQL_NTS, (SQLCHAR*)"sa", SQL_NTS, (SQLCHAR*)"123456", SQL_NTS);
	//“mytest”是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 TEXT";//使用名为"TEXT"数据库,读者根据自己创建的数据库名称进行修改
	SQLCHAR sql2[] = "select * from Studentlnfo";//查询已创建好的名为"StudentInfo"表所有列
	retcode = SQLExecDirect(hstmt, sql1, SQL_NTS);//SQLExecDirect,此函数用于执行SQL语句,执行sql1语句,即"use TEXT"
	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\t%s\t%s\n",str1,str2,str3,str4,str5);
		}
	}
	printf("process finish\n");
	SQLFreeHandle(SQL_HANDLE_DBC, hdbc);//释放连接句柄
	SQLFreeHandle(SQL_HANDLE_ENV, henv);//释放环境句柄

}

6.进行调试

  • 连接数据库成功,并且成功获取表格数据

在 C 语言中,连接 SQL Server 数据库可以使用 Microsoft 提供的 ODBC API 接口。下面是一个简单的连接 SQL Server 数据库的示例代码: ``` #include <stdio.h> #include <stdlib.h> #include <sql.h> #include <sqlext.h> int main() { SQLHENV env; // 环境句柄 SQLHDBC dbc; // 连接句柄 SQLRETURN ret; // 返回值 // 初始化环境句柄 ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &env); if (ret != SQL_SUCCESS && ret != SQL_SUCCESS_WITH_INFO) { printf("Failed to allocate environment handle\n"); return 1; } // 设置环境属性 ret = SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, 0); if (ret != SQL_SUCCESS && ret != SQL_SUCCESS_WITH_INFO) { printf("Failed to set environment attribute\n"); SQLFreeHandle(SQL_HANDLE_ENV, env); return 1; } // 分配连接句柄 ret = SQLAllocHandle(SQL_HANDLE_DBC, env, &dbc); if (ret != SQL_SUCCESS && ret != SQL_SUCCESS_WITH_INFO) { printf("Failed to allocate connection handle\n"); SQLFreeHandle(SQL_HANDLE_ENV, env); return 1; } // 连接数据库 SQLCHAR* conn_str = "Driver={SQL Server};Server=localhost;Database=mydb;Uid=myusername;Pwd=mypassword;"; ret = SQLDriverConnect(dbc, NULL, conn_str, SQL_NTS, NULL, 0, NULL, SQL_DRIVER_COMPLETE); if (ret != SQL_SUCCESS && ret != SQL_SUCCESS_WITH_INFO) { printf("Failed to connect to database\n"); SQLFreeHandle(SQL_HANDLE_DBC, dbc); SQLFreeHandle(SQL_HANDLE_ENV, env); return 1; } // 连接成功 printf("Connected to database successfully\n"); // 断开连接 SQLDisconnect(dbc); // 释放连接句柄和环境句柄 SQLFreeHandle(SQL_HANDLE_DBC, dbc); SQLFreeHandle(SQL_HANDLE_ENV, env); return 0; } ``` 需要注意的是,连接字符串 `conn_str` 中需要填写正确的 SQL Server 服务器、数据库、用户名和密码等信息。另外,连接成功后可以使用 ODBC API 提供的函数执行 SQL 查询语句等操作。
评论 30
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值