DataGridView控件具有极高的可配置性和可扩展性。它提供有大量的属性、方法和事件,能够用来对该控件的外观和行为进行自己定义。以下通过一个小样例来展示DataGridView进行增删改查,并同步到数据库的功能。

窗口展示:

a4c26d1e5885305701be709a3d33442f.png

用户需求:

1.当窗口显示时,将数据库中用户表中的数据显示出来。

2.选中一行,运行删除操作,同一时候在数据库中对应数据被删除。

3.双击某个数据,进行编辑,或者在空白行加入新的数据,然后点击更新,数据库随之更新。

代码展示:

Public Class Form1'代码较简单,没有使用三层架构。

Public DT As DataTable

Public SDA As SqlDataAdapter

Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load

Dim conn = New SqlConnection("Server=***;DataBase=userinfo;User ID=***;Password=***")

SDA = New SqlDataAdapter("select * from Users", conn)

DT = New DataTable

SDA.Fill(DT) '将查到的数据传到DataTable中

DataGridView1.DataSource = DT '将DataTable中的数据传给DataGridView1显示

End Sub

'

更新操作

Private Sub btnUpdate_Click(sender As Object, e As EventArgs) Handles btnUpdate.Click

Dim SCB = New SqlCommandBuilder(SDA)

SDA.Update(DT)

MsgBox("更新成功")

End Sub

'删除操作

Private Sub btnDel_Click(sender As Object, e As EventArgs) Handles btnDel.Click

'删除选中行

DataGridView1.Rows.RemoveAt(DataGridView1.CurrentCell.RowIndex)

'数据库中进行删除

Dim SCB = New SqlCommandBuilder(SDA)

SDA.Update(DT)

MsgBox("删除成功")

End Sub

End Class

注意:

1.数据库中对应的表中一定要有主键。

2.DataGridView启用编辑和删除功能。

代码解析:

a4c26d1e5885305701be709a3d33442f.png

1.DataSet与DataTable:

DataSet:数据集,简单理解为一个暂时数据库,将数据源的数据保存在内存中,独立于不论什么数据库。一般包括多个DataTable,以及DataTable之间的约束关系。通过

dataset["表名"]得到DataTable 。

2.SqlDataAdapter:SqlDataAdapter对象名=new SqlDataAdapter(查询用sql语句,数据库连接);

Fill方法向数据表中填充数据。Update方法将数据表中的数据提交到数据库。

3.SqlCommandBuilder对象:

SqlCommandBuilder

builder =new SqlCommandBuilder(已创建的DataAdapter对象);

利用SqlCommandBuilder对象可以自己主动生成:INSERT命令、UPDATE命令、DELETE命令。

以上展示的仅仅是冰山一角,DataGridView的功能特别强悍。学无止境!

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐