c#&数据库: 8.在窗体上显示学生信息

以上一章学生信息表为例,首先将查询的学生信息存储到数据集中,然后将数据集与数据显示控件绑定,从而实现学生信息在窗体上的显示

(1)创建一个名为StudentGridView的窗体应用程序,为窗体添加一个DataGridView控件。

(2)重写窗体的OnLoad事件函数,添加数据库查询代码如下:

cs 复制代码
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace StudentGridView
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        protected override void OnLoad(EventArgs e)
        {

            SqlDataAdapter adapter = new SqlDataAdapter("SELECT * FROM staq_info",
         "Data Source=.\\SQLExpress;Database=aq;Trusted_Connection=true;");
            DataSet dataSet = new DataSet();                       //创建数据集对象
            adapter.Fill(dataSet);                                 //将查询结果填充到数据集
            dGVStudent.DataSource = dataSet.Tables[0];             //将数据集绑定到DataGridView控件上
        }
        
    }
}

运行C#代码:

本实例代码主要利用数据表视图控件在窗体上显示查询结果。首先通过SqlDataAdapter类实现数据的查询,然后将查询结果填充到DataSet对象中,最后将DataSet对象的Tables[0]绑定到数据表视图控件DataGridView的DataSource属性上。此时查询结果便显示在了窗体的DataGridView控件中。

在上面的代码中,OnLoad方法被标记为override,这意味着它正在重写基类(Form类)中的同名方法。base.OnLoad(e);这行代码调用了基类中的OnLoad方法,因为基类的OnLoad方法执行了一些必要的初始化操作.注意,你不需要(也不应该)在窗体的构造函数中直接调用OnLoad方法。Windows Forms框架会在适当的时候自动调用它。

相关推荐
bzmK1DTbd4 小时前
Git版本控制:Java项目中的分支管理与合并策略
java·开发语言·git
Rust研习社4 小时前
为什么 Rust 没有空指针?
开发语言·后端·rust
kyriewen114 小时前
WebAssembly:前端界的“外挂”,让C++代码在浏览器里跑起来
开发语言·前端·javascript·c++·单元测试·ecmascript
其实防守也摸鱼6 小时前
CTF密码学综合教学指南--第九章
开发语言·网络·python·安全·网络安全·密码学·ctf
砚底藏山河6 小时前
Python量化开发:2026最佳实时股票数据API接口推荐与对比
开发语言·windows·python
AlunYegeer7 小时前
JAVA,以后端的视角理解前端。在全栈的路上迈出第一步。
java·开发语言·前端
hixiong1237 小时前
C# OpenvinoSharp使用DINOv2模型进行图像相似度计算
开发语言·c#
DFT计算杂谈8 小时前
自动化脚本一键绘制三元化合物相图
java·运维·服务器·开发语言·前端·python·自动化
EW Frontier8 小时前
6G ISAC新范式:基于智能漏波天线的Wi‑Fi通感一体化系统设计与实测【附MATLAB+python代码】
开发语言·python·matlab·music·isac·doa·wi‑fi
楼田莉子8 小时前
Linux网络:NAT_代理
linux·运维·服务器·开发语言·c++·后端