zoukankan      html  css  js  c++  java
  • datagridview绑定数据源的几种常见方式

    /////////////开始以前,先认识一下WinForm控件数据绑定的两种形式,简单数据绑定和复杂数据绑定。 
    //////////////1) 简单数据绑定 
    //////////////////using (SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["connStr"].ToString())) 
    //////////////////{ 
    ////////////////// SqlDataAdapter sda = new SqlDataAdapter("Select * From T_Class Where F_Type='Product' order by F_RootID,F_Orders", conn); 
    ////////////////// DataSet Ds = new DataSet(); 
    ////////////////// sda.Fill(Ds, "T_Class"); 

    ////////////////// //使用DataSet绑定时,必须同时指明DateMember 
    ////////////////// //this.dataGridView1.DataSource = Ds; 
    ////////////////// //this.dataGridView1.DataMember = "T_Class"; 

    ////////////////// //也可以直接用DataTable来绑定 
    ////////////////// this.dataGridView1.DataSource = Ds.Tables["T_Class"]; 
    //////////////////} 
    //////////////简单的数据绑定是将用户控件的某一个属性绑定至某一个类型实例上的某一属性。采用如下形式进行绑定:引用控件.DataBindings.Add("控件属性", 实例对象, "属性名", true); 
    //////////////2) 复杂数据绑定 
    //////////////复杂的数据绑定是将一个以列表为基础的用户控件(例如:ComboBox、ListBox、ErrorProvider、DataGridView等控件)绑定至一个数据对象的列表。 
    //////////////基本上,Windows Forms的复杂数据绑定允许绑定至支持IList接口的数据列表。此外,如果想通过一个BindingSource组件进行绑定,还可以绑定至一个支持IEnumerable接口的数据列表。 
    //////////////对于复杂数据绑定,常用的数据源类型有(代码以DataGridView作为示例控件): 

    using System; 
    using System.Collections.Generic; 
    using System.ComponentModel; 
    using System.Data; 
    using System.Drawing; 
    using System.Text; 
    using System.Windows.Forms; 
    using System.Collections; 

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


    private void button1_Click(object sender, EventArgs e) 
    { 
    //this.dataGridView1.DataSource = DataBindingByList1(); 

    //this.dataGridView1.DataSource = DataBindingByList2(); 

    //this.dataGridView1.DataSource = DataBindingByDataTable(); 
    this.dataGridView1.DataSource = DataBindingByBindingSource(); 

    } 

    /// <summary> 
    /// IList接口(包括一维数组,ArrayList等) 
    /// </summary> 
    /// <returns></returns> 
    private ArrayList DataBindingByList1() 
    { 
    ArrayList Al = new ArrayList(); 
    Al.Add(new PersonInfo("a","-1")); 
    Al.Add(new PersonInfo("b","-2")); 
    Al.Add(new PersonInfo("c","-3")); 
    return Al; 
    } 

    /// <summary> 
    /// IList接口(包括一维数组,ArrayList等) 
    /// </summary> 
    /// <returns></returns> 
    private ArrayList DataBindingByList2() 
    { 
    ArrayList list = new ArrayList(); 
    for (int i = 0; i < 10; i++) 
    { 
    list.Add(new DictionaryEntry(i.ToString(),i.ToString()+"_List")); 
    } 
    return list; 
    } 


    /// <summary> 
    /// IListSource接口(DataTable、DataSet等) 
    /// </summary> 
    /// <returns></returns> 
    private DataTable DataBindingByDataTable() 
    { 
    DataTable dt = new DataTable(); 
    DataColumn dc1 = new DataColumn("Name"); 
    DataColumn dc2 = new DataColumn("Value"); 

    dt.Columns.Add(dc1); 
    dt.Columns.Add(dc2); 

    for (int i = 1; i <= 10; i++) 
    { 
    DataRow dr = dt.NewRow(); 
    dr[0] = i; 
    dr[1] = i.ToString() + "_DataTable"; 
    dt.Rows.Add(dr); 
    } 

    return dt; 
    } 


    /// <summary> 
    /// IBindingListView接口(如BindingSource类) 
    /// </summary> 
    /// <returns></returns> 
    private BindingSource DataBindingByBindingSource() 
    { 
    Dictionary<string, string> dic = new Dictionary<string, string>(); 
    for (int i = 0; i < 10; i++) 
    { 
    dic.Add(i.ToString(),i.ToString()+"_Dictionary"); 
    } 
    return new BindingSource(dic,null); 
    } 


    } 
    } 

    //////////////////上面代码中BindingSource的Datasource是一个结构类型DictionaryEntry,同样的DictionaryEntry并不能直接赋值给Combobox的DataSource,但通过BindingSource仍然可以间接实现。 
    ////////////////// 这是因为: 
    //////////////////BindingSource可以作为一个强类型的数据源。其数据源的类型通过以下机制之一固定: 
    //////////////////· 使用 Add 方法可将某项添加到 BindingSource 组件中。 
    //////////////////· 将 DataSource 属性设置为一个列表、单个对象或类型。(这三者并不一定要实现IList或IListSource) 
    //////////////////这两种机制都创建一个强类型列表。BindingSource 支持由其 DataSource 和 DataMember 属性指示的简单数据绑定和复杂数据绑定。

  • 相关阅读:
    XAF 有条件的对象访问权限
    XAF 顯示 UnInplace Report(設置自定義條件顯示報表,不是根據選擇ListView記錄條件顯示報表)
    XAF 如何自定义PivotGrid单元格显示文本?
    XAF 如何布局详细视图上的按钮
    XAF How to set size of a popup detail view
    XAF Delta Replication Module for Devexpress eXpressApp Framework
    XAF 帮助文档翻译 EasyTest Basics(基础)
    XAF 用户双击ListView记录时禁止显示DetailView
    XAF How to enable LayoutView mode in the GridControl in List Views
    XAF 如何实现ListView单元格批量更改?
  • 原文地址:https://www.cnblogs.com/ArRan/p/2749681.html
Copyright © 2011-2022 走看看