IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> C# 将数据库SqlServer数据绑定到类中 -> 正文阅读

[大数据]C# 将数据库SqlServer数据绑定到类中

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


目录

一、环境和过程

环境:

过程:

三、代码?

(一)Form_Load方法

(二)LoadData方法

(三)TblPerson类


?一、环境和过程

环境:

  • 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; }
    }

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-06-18 23:28:02  更:2022-06-18 23:29:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 11:10:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码