C# Winform DataGridView 控件和 DataTable

目录

一、概述

二、DataTable 的用法

1.创建表和列

2.添加行

3.取值和赋值

4.删除行

5.遍历 DataTable

6.判断 DataTable 列中是否存在某个值

7.设置主键

8.获取 DataRow 所在的行号

9.DataTable 转换为 List

10.将 List 转 DataTable

三、DataGridView 的用法

1.绑定数据

2.获取绑定的数据源

3.获取 / 设置 选中单元格的数据

4.设置单元格的宽高

结束

一、概述

DataGridView 控件提供用于显示数据的可自定义表。 类 DataGridView 允许通过使用属性(如 DefaultCellStyle、 ColumnHeadersDefaultCellStyle、 CellBorderStyle和)自定义单元格、行、列和 GridColor边框。 有关详细信息,请参阅微软 DataGridView 控件中的基本格式设置和样式设置。

可以使用 DataGridView 控件在基础数据源中或不使用基础数据源显示数据。 如果不指定数据源,可以创建包含数据的列和行,并将其直接添加到 DataGridView using Rows and Columns properties。 还可以使用 Rows 集合访问 DataGridViewRow 对象和 DataGridViewRow.Cells 属性来直接读取或写入单元格值。 索引 Item[] 器还提供对单元格的直接访问。

作为手动填充控件的替代方法,可以设置 DataSource 属性 DataMember 以绑定到 DataGridView 数据源并自动填充数据。 有关详细信息,请参阅微软 DataGridView 控件中显示数据。

处理大量数据时,可以将属性设置为 VirtualModetrue 显示可用数据的子集。 虚拟模式需要实现在其中填充控件的数据缓存 DataGridView 。

二、DataTable 的用法

1.创建表和列

使用 new DataTable() 来创建一个 DataTable 表,创建表可以加上表名,也可以不加

DataTable dt = new DataTable();
DataTable dt1 = new DataTable("Datas");

DataTable 表 和我们常用的 Excel 是一样的,如下图,列就是 A,B,C,D…   行就是 1,2,3,4…

https://img-blog.csdnimg.cn/d9f9c198e55d411aac1f5ac11d83297f.png

只是 DataTable 在创建后,是空的,既没有自动创建的列,也没有自动创建的行,这些都是要我们通过代码来实现的。

创建列通过 实例化 DataColumn 类,并 DataColumn 类 添加到 DataTable.Columns 中来实现添加一列。

DataTable dt = new DataTable("Datas");
DataColumn dc1 = new DataColumn("商品编号");
DataColumn dc2 = new DataColumn("商品名称");
DataColumn dc3 = new DataColumn("商品重量");
DataColumn dc4 = new DataColumn("商品价格");
DataColumn dc5 = new DataColumn("购买数量");
dt.Columns.Add(dc1);
dt.Columns.Add(dc2);
dt.Columns.Add(dc3);
dt.Columns.Add(dc4);
dt.Columns.Add(dc5);

在添加列的同时,可以给列添加一些设置

DataTable dt = new DataTable("Datas");
DataColumn dc1 = new DataColumn("商品编号");
DataColumn dc2 = new DataColumn("商品名称");
DataColumn dc3 = new DataColumn("商品重量");
DataColumn dc4 = new DataColumn("商品价格");
DataColumn dc5 = new DataColumn("购买数量");

dc1.AutoIncrement = true;//自动增加
dc1.AutoIncrementSeed = 1;//起始为1
dc1.AutoIncrementStep = 1;//步长为1
dc1.AllowDBNull = false;//是否允许空值
			
dt.Columns.Add(dc1);
dt.Columns.Add(dc2);
dt.Columns.Add(dc3);
dt.Columns.Add(dc4);
dt.Columns.Add(dc5);

只是这么做比较繁琐,因此不推荐。

推荐用下面方式去添加列

DataTable dt = new DataTable("Datas");
DataColumn dc = new DataColumn();
dc.AutoIncrement = true;//自动增加
dc.AutoIncrementSeed = 1;//起始为1
dc.AutoIncrementStep = 1;//步长为1
dc.AllowDBNull = false;//是否允许空值

//添加列
dt.Columns.Add("姓名", typeof(string));
dt.Columns.Add("年龄", typeof(int));
dt.Columns.Add("身高", typeof(float));
dt.Columns.Add("体重", typeof(float));

dataGridView1.DataSource = dt;

效果:

https://img-blog.csdnimg.cn/b8e393cacabc404abcf8df0c4f360530.png

可以看到,DataGridView 在绑定 DataTable 后会默认出现一个空白的行,你可能会有疑问,是不是这句代码导致的,如下:

dc.AutoIncrement = true;//自动增加
dc.AutoIncrementSeed = 1;//起始为1
dc.AutoIncrementStep = 1;//步长为1
dc.AllowDBNull = false;//是否允许空值

开始测试:

private void Form1_Load(object sender, EventArgs e)
{
   
    DataTable dt = new DataTable("Datas");
    //添加列
    dt.Columns.Add("姓名", typeof(string));
    dt.Columns.Add("年龄", typeof(int));
    dt.Columns.Add("身高", typeof(float));
    dt.Columns.Add("体重", typeof(float));

    dt.Rows.Add("2号", 12, 220, 300);

    dataGridView1.DataSource = dt;
}

效果:

https://img-blog.csdnimg.cn/6abfa678283346849161cb269a5c14b7.png

所以实验证明,用 DataTable 绑定数据,是会默认添加一个空白行的,如果不想表格中有空白行,可以使用  List<类> 这种方式去绑定,参考下面代码:

using System;
using System.Collections.Generic;
using System.Windows.Forms;

namespace DateTable的使用
{
   
    public partial class Form1 : Form
    {
   
        public Form1()
        {
   
            InitializeComponent();
        }

        List<dog> doglist = new List<dog>();

        private void Form1_Load(object sender, EventArgs e)
        {
   
            doglist.Add(new dog() {
    name = "dog1", age = 1, color = "bule", gender = 1 });
            doglist.Add(new dog() {
    name = "dog2", age = 2, color = "green", gender = 0 });
            doglist.Add(new dog() {
    name = "dog3", age = 3, color = "red", gender = 1 });

            dataGridView1.DataSource = doglist;
        }
    }
}

public class dog
{
   
    public string name {
    get; set; }
    public int age {
    get; set; }
    public string color {
    get; set; }
    public int gender {
    get; set; }
}

效果:

https://img-blog.csdnimg.cn/5c7dc104b6e149d1ad0aca6d9b717015.png

2.添加行

通过添加 DataRow 类来添加行,如下:

DataTable dt = new DataTable("Datas");
DataColumn dc = new DataColumn();
dc.AutoIncrement = true;//自动增加
dc.AutoIncrementSeed = 1;//起始为1
dc.AutoIncrementStep = 1;//步长为1
dc.AllowDBNull = false;//是否允许空值

//添加列
dt.Columns.Add("姓名", typeof(string));
dt.Columns.Add("年龄", typeof(int));
dt.Columns.Add("身高", typeof(float
  • 18
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值