C# 将数据库SqlServer数据绑定到类中的过程详解

 更新时间:2022年06月17日 10:14:25   作者:陈_  
本文讲述的是读取数据库中数据的常用做法,即将数据库中的数据绑定到创建的类中,再将类绑定到DataGridView的数据源中的做法,对C#将SqlServer数据绑定到类中感兴趣的朋友一起看看吧

本文讲述的是读取数据库中数据的常用做法,即将数据库中的数据绑定到创建的类中,再将类绑定到DataGridView的数据源中的做法。

 一、环境和过程

环境:

  • Visual Studio 2015
  • SQL Server 2012
  • Windows窗体应用程序

过程:

1、添加DataGridView,如下图:

2、在窗口的Form_Load方法中添加代码,通过读取数据库将数据库TblPerson的数据读取到DataGridView中,数据库TblPerson的数据如下:

3、结果如下图,启动程序时,数据直接加载到DataGridView中:

三、代码 

(一)Form_Load方法

注意:这里将主要的代码封装到LoadData方法中。

在窗口加载时,该方法将数据库中的数据加载到DataGridView中。

        /// <summary>
        /// 在窗口加载时,将数据库中的数据加载到DataGridView中
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Form1_Load(object sender, EventArgs e)
        {
            LoadData();
        }

(二)LoadData方法

这是本文的主要代码。

注意

1、数据库中的数据可能有null值,需要判断是否为null,然后利用int?的强制转换和三元判断式的方法来转换数据。

2、需要提前写好数据绑定的类。

        /// <summary>
        /// 加载数据的主要方法,通过数据绑定到类中,再将类集合绑定到DataGridView的方法
        /// </summary>
        private void LoadData()
        {
            //这个集合包含了数据库中每一行数据
            List<TblPerson> lstTblPerson = new List<TblPerson>();
            //连接字符串
            string conStr = "server=.;database=Itcast2014;integrated security=true;";
            using (SqlConnection con=new SqlConnection(conStr))
            {
                //命令字符串,读取所有数据
                string cmdTxt = "select * from TblPerson";
                using (SqlCommand cmd=new SqlCommand(cmdTxt,con))
                {
                    con.Open();
                    using (SqlDataReader reader=cmd.ExecuteReader())
                    {
                        if (reader.HasRows)
                        {
                            //一行一行读取数据
                            while (reader.Read())
                            {
                                //创建数据类的对象,并将数据库读取到的每一个单元格的数据绑定到类的属性中
                                TblPerson model = new TblPerson();
                                //因为有的数据有null值,所以需要先看看是否是null
                                model.autoId =reader.IsDBNull(0)? null :(int?) reader.GetInt32(0);
                                model.uName = reader.IsDBNull(1) ? null : reader.GetString(1);
                                model.age=reader.IsDBNull(2) ? null : (int?)reader.GetInt32(2);
                                model.height= reader.IsDBNull(3) ? null : (int?)reader.GetInt32(3);
                                model.gender =reader.IsDBNull(4) ? null : (bool?)reader.GetBoolean(4);
                                lstTblPerson.Add(model);
                            }
                        }
                    }
                    con.Close();
                }
            }
            //数据绑定需要注意一点:
            //数据绑定的时候,只认属性不认字段,所以在类中要设置对应的属性,内部通过反射实现
            dataGridView1.DataSource = lstTblPerson;
        }

(三)TblPerson类

将数据库中的数据绑定到TblPerson类中, 类的每一个属性对应数据库中表的每一个字段。

注意

1、因为数据库中的数据有null值,所以用int?定义属性的类型,即既可以是int类型,也可以是null类型。

2、数据绑定的时候,只认属性不认字段,所以在类中要设置对应的属性,内部通过反射实现

    public class TblPerson
    {
        //这里用到了int?是因为,数据库中的值有可能是空值,此时需要设置值为null
        public int? autoId { get; set; }
        public string uName { get; set; }
        public int? age { get; set; }
        public int? height { get; set; }
        public bool? gender { get; set; }
    }

到此这篇关于C# 将数据库SqlServer数据绑定到类中的文章就介绍到这了,更多相关C# SqlServer数据绑定到类中内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#异步调用的好处和方法分享

    C#异步调用的好处和方法分享

    我们要明确,为什么要进行异步回调?众所周知,普通方法运行,是单线程的,如果中途有大型操作(如:读取大文件,大批量操作数据库,网络传输等),都会导致方法阻塞,表现在界面上就是,程序卡或者死掉,界面元素不动了,不响应了
    2012-04-04
  • C#交换两个变量值的几种方法总结

    C#交换两个变量值的几种方法总结

    这篇文章介绍了C#交换两个变量值的几种方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • C# 9.0新特性——扩展方法GetEnumerator支持foreach循环

    C# 9.0新特性——扩展方法GetEnumerator支持foreach循环

    这篇文章主要介绍了C# 9.0新特性——扩展方法GetEnumerator支持foreach循环的相关资料,帮助大家更好的理解和学习c# 9.0,感兴趣的朋友可以了解下
    2020-11-11
  • c#数字图像处理的3种方法示例分享

    c#数字图像处理的3种方法示例分享

    这篇文章主要介绍了c#数字图像处理的3种方法示例,需要的朋友可以参考下
    2014-02-02
  • C#利用LINQ实现一个文件拆分成多个文件的示例详解

    C#利用LINQ实现一个文件拆分成多个文件的示例详解

    在日常开发过程中,我们可能会遇到需要将一个大型文件拆分成多个小文件的需求,例如,为了便于传输、处理或备份,在C#中,我们可以利用LINQ技术来实现这一功能,下面我将详细介绍如何使用LINQ拆分文件,需要的朋友可以参考下
    2024-08-08
  • C#中Dapper的使用教程

    C#中Dapper的使用教程

    Dapper是一款轻量级ORM工具(Github),Dapper语法十分简单。并且无须迁就数据库的设计,今天通过本文给大家介绍C# Dapper的使用,感兴趣的朋友一起看看吧
    2021-07-07
  • unity shader实现玻璃折射效果

    unity shader实现玻璃折射效果

    这篇文章主要为大家详细介绍了unity shader实现玻璃折射效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • C#取得随机颜色的方法

    C#取得随机颜色的方法

    这篇文章主要介绍了C#取得随机颜色的方法,通过自定义函数实现随机颜色的功能,非常具有实用价值,需要的朋友可以参考下
    2015-01-01
  • C#使用Windows Service的简单教程(创建、安装、卸载、调试)

    C#使用Windows Service的简单教程(创建、安装、卸载、调试)

    这篇文章主要为大家详细介绍了C#创建、安装、卸载、调试Windows Service(Windows 服务)的简单教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • C#中DataTable实现筛选查询的示例

    C#中DataTable实现筛选查询的示例

    本文主要介绍了C#中DataTable实现筛选查询的示例,主要是DataTable进行过滤筛选,常用的一些方法为:Select,dataview,具有一定的参考价值,感兴趣的可以了解一下
    2023-04-04

最新评论