C#连接SQL Server实现DataGridView数据填充
4星 · 超过85%的资源 需积分: 49 66 浏览量
更新于2024-09-14
收藏 920B TXT 举报
在C#编程中,将SQL Server数据库中的数据读取并显示在DataGridView控件中是一项常见的任务,特别是在开发Windows应用程序时。这里我们关注的是如何通过ADO.NET连接到SQL Server,执行SQL查询,填充DataSet,然后将结果集展示在DataGridView上。
首先,创建一个名为`button1_Click`的事件处理器方法,该方法是按钮被点击时触发的。在这个方法内部,我们需要设置连接到SQL Server的配置,包括服务器地址、用户名(如sa)、密码以及要操作的数据库(这里是`table1`):
```csharp
private void button1_Click(object sender, EventArgs e)
{
// 创建DataSet对象用于存储查询结果
DataSet ds = new DataSet();
// 使用SqlConnection对象连接到SQL Server
using (SqlConnection conn = new SqlConnection())
{
conn.ConnectionString = "server=localhost;uid=sa;pwd=123456;database=table1";
conn.Open(); // 打开数据库连接
// 创建SqlCommand对象,用于执行SQL命令
using (SqlCommand command = conn.CreateCommand())
{
// 设置SQL查询语句(这里假设表名为gongneng)
command.CommandText = "select * from gongneng";
// 使用SqlDataAdapter填充DataSet
SqlDataAdapter da = new SqlDataAdapter(command);
try
{
da.Fill(ds); // 尝试填充数据到DataSet
}
catch {}
}
}
}
```
在上述代码中,关键步骤如下:
1. 创建DataSet和SqlConnection对象:DataSet是一个用于存储来自多个数据源的数据集合,而SqlConnection用于连接到SQL Server。
2. 打开数据库连接:通过调用`Open()`方法打开与SQL Server的连接。
3. 创建SqlCommand对象:SqlCommand用于执行SQL命令。在这里,我们设置了查询所有`gongneng`表中的列。
4. 使用SqlDataAdapter填充DataSet:SqlDataAdapter负责从数据库获取数据,并将其填充到DataSet中。`Fill()`方法会填充DataSet的当前表(默认是第一个表)。
5. 处理异常:`try-catch`结构用于捕获可能在执行SQL查询时出现的异常,防止程序崩溃。
6. 将数据绑定到DataGridView:在填充完DataSet后,我们创建一个新的DataTable对象(`DataTable dt = ds.Tables[0].Copy();`),并将其赋值给DataGridView的DataSource属性,从而将数据显示在DataGridView上。
这样,当用户点击按钮时,程序会从SQL Server查询`gongneng`表中的所有数据,并在DataGridView控件中动态显示出来。这个例子展示了基本的C#与SQL Server交互,用于数据绑定和可视化。在实际应用中,可能还需要考虑分页、错误处理和性能优化等因素。
2013-03-30 上传
2018-05-14 上传
点击了解资源详情
2024-11-01 上传
171 浏览量
133 浏览量
493 浏览量
154 浏览量
JINGNSS
- 粉丝: 25
- 资源: 15
最新资源
- C语言数组操作:高度检查器编程实践
- 基于Swift开发的嘉定单车LBS iOS应用项目解析
- 钗头凤声乐表演的二度创作分析报告
- 分布式数据库特训营全套教程资料
- JavaScript开发者Robert Bindar的博客平台
- MATLAB投影寻踪代码教程及文件解压缩指南
- HTML5拖放实现的RPSLS游戏教程
- HT://Dig引擎接口,Ampoliros开源模块应用
- 全面探测服务器性能与PHP环境的iprober PHP探针v0.024
- 新版提醒应用v2:基于MongoDB的数据存储
- 《我的世界》东方大陆1.12.2材质包深度体验
- Hypercore Promisifier: JavaScript中的回调转换为Promise包装器
- 探索开源项目Artifice:Slyme脚本与技巧游戏
- Matlab机器人学习代码解析与笔记分享
- 查尔默斯大学计算物理作业HP2解析
- GitHub问题管理新工具:GIRA-crx插件介绍