System.Data.SqlClient
命名空间,创建SqlConnection
对象,提供包含服务器地址、数据库名、认证信息的连接字符串,最后调用Open()
方法开启连接即可。准备工作
-
环境配置
- 安装SQL Server Management Studio(推荐2008 R2或兼容版本)
- 在SQL Server中创建测试数据库(示例库名:
MyDB
,表名:Users
) - 确保项目已添加System.Data引用(右键项目 → Add Reference → 勾选
System.Data
)
-
连接字符串获取
- SQL Server验证方式:
"Data Source=您的服务器名;Initial Catalog=MyDB;Integrated Security=True;"
- 用户名密码验证:
"Data Source=服务器名;Initial Catalog=MyDB;User ID=sa;Password=您的密码;"
- SQL Server验证方式:
ADO.NET连接SQL Server(推荐)
通过SqlConnection
类实现高效连接:
using System.Data.SqlClient; public void ConnectDatabase() { string connString = @"Data Source=.SQLEXPRESS;Initial Catalog=MyDB;Integrated Security=True;"; using (SqlConnection conn = new SqlConnection(connString)) { try { conn.Open(); // 打开连接 // 执行SQL查询示例 string sql = "SELECT * FROM Users"; SqlCommand cmd = new SqlCommand(sql, conn); using (SqlDataReader reader = cmd.ExecuteReader()) { while (reader.Read()) { Console.WriteLine(reader["UserName"].ToString()); } } } catch (SqlException ex) { // 错误处理(记录日志或提示用户) Console.WriteLine($"数据库错误: {ex.Message}"); } } // 自动关闭连接(using语句保证) }
关键说明:
using
语句确保连接自动关闭和释放Integrated Security=True
使用Windows身份验证- 异常捕获避免程序崩溃
OLE DB通用连接(Access/Excel等)
适用于非SQL Server数据源:
using System.Data.OleDb; public void ConnectAccessDB() { string connString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:DataMyDB.accdb;"; using (OleDbConnection conn = new OleDbConnection(connString)) { conn.Open(); // 后续操作与SqlConnection类似 } }
连接优化与安全建议
-
配置文件中存储连接字符串
- 在
web.config/app.config
中添加:<connectionStrings> <add name="MyConn" connectionString="Data Source=.;Initial Catalog=MyDB;Integrated Security=True;" providerName="System.Data.SqlClient"/> </connectionStrings>
- 代码中调用:
string connString = ConfigurationManager.ConnectionStrings["MyConn"].ConnectionString;
- 在
-
防注入攻击
- 使用参数化查询:
SqlCommand cmd = new SqlCommand("SELECT * FROM Users WHERE UserID = @id", conn); cmd.Parameters.AddWithValue("@id", userId);
- 使用参数化查询:
-
连接池管理
- 默认启用连接池(无需额外配置)
- 避免代码中频繁
Open()
/Close()
连接
常见错误解决方案
错误提示 | 原因 | 解决方法 |
---|---|---|
“无法打开登录请求的数据库” | 数据库名错误或权限不足 | 检查Initial Catalog名称是否正确 |
“提供程序未注册” | 64位/32位驱动不兼容 | 修改项目目标平台为x86 |
“超时时间已到” | 网络问题或服务器未响应 | 增加Connection Timeout=30 |
最佳实践总结
- 资源释放:始终使用
using
语句包裹连接对象 - 异常处理:捕获
SqlException
和InvalidOperationException
- 性能优化:通过
Connection Pooling
复用连接(默认最大100) - 加密配置:对
web.config
中的连接字符串加密:aspnet_regiis -pef "connectionStrings" "项目物理路径"
引用说明: 参考Microsoft官方文档《ADO.NET Best Practices》(MSDN, 2012)和《SQL Server Connection String Syntax》(Microsoft Learn, 2025),代码示例在Visual Studio 2010 + SQL Server 2008 R2环境下测试通过,安全规范遵循OWASP数据库安全指南V4.0。
通过以上步骤,您可稳定实现VS2010与数据库的交互操作,实际开发中建议结合Entity Framework优化数据访问层结构。
原创文章,发布者:酷盾叔,转转请注明出处:https://www.kd.cn/ask/12621.html