怎么在C#中利用DataGridView綁定數據源?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
1. 簡單的數據綁定
例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
從數據庫中把數據讀出來放到一個數據集中,比如List<>、DataTable,DataSet,我一般用List<>,
然后綁定數據源:
IList<student> sList=StudentDB.GetAllList(); DataGridView.DataSource=sList;
如果你沒有設置DataGridView的列,它會自動生成所有列。
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 屬性指示的簡單數據綁定和復雜數據綁定。
總結:
根據DataSource綁定的對象的不同,可以有一下幾種簡單的綁定:
// DataSet 、DataTable // 方式1 DataSet ds=new DataSet (); this.dataGridView1.DataSource=ds.Table[0]; this.dataGridView1.DataSource = ds.Tables["表名"]; // 方式2 DataTable dt=new DataTable(); this.dataGridView1.DataSource=dt; // DataView DataView dv = new DataView(); this.dataGridView1.DataSource = dv; // 設置了DataMember DataSet ds=new DataSet (); this.dataGridView1.DataSource = ds; this.dataGridView1.DataMember = "表名"; // ArrayList ArrayList Al = new ArrayList(); this.dataGridView1.DataSource = Al; // dic Dictionary<string, string> dic = new Dictionary<string, string>(); this.dataGridView1.DataSource = dic; // List<Object> this.dataGridVi.DataSource = new BindingList<Object>(List<Object>);
3. 實例
3.1 手動給dataGridView綁定數據源的方法
C#中手動給dataGridView綁定數據源,能夠很自由地進行操作,但展示數據并沒有C#自動添加數據源那么方便??捎袝r為了方便操作數據,我們更愿意手動連接數據源,代碼如下:
conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Restaurant.mdb");//建立數據庫連接
cmd = new OleDbCommand("select * from data", conn);//執行數據連接
DataSet ds = new DataSet();
OleDbDataAdapter da = new OleDbDataAdapter(cmd);
da.Fill(ds);
this.dataGridView1.DataSource = ds.Tables[0];//數據源
this.dataGridView1.AutoGenerateColumns = false;//不自動
conn.Close();//關閉數據庫連接說明:解決DataGridView綁定了數據源無法更新保存當前行的問題
this.dataGridView.currentCell=null;//該行的作用是取消datagridview行的編輯狀態 adapter.Update(userTable);
3.2 利用泛型集合向DataGridView中添加數據
List<>泛型集合:
private void Form1_Load(object sender, EventArgs e)
{
//使用List<>泛型集合填充DataGridView
List<Student> students = new List<Student>();
Student hat = new Student("Hathaway", "12", "Male");
Student peter = new Student("Peter","14","Male");
Student dell = new Student("Dell","16","Male");
Student anne = new Student("Anne","19","Female");
students.Add(hat);
students.Add(peter);
students.Add(dell);
students.Add(anne);
this.dataGridView1.DataSource = students;
}Dictionary<>泛型集合
private void Form1_Load(object sender, EventArgs e)
{
//使用Dictionary<>泛型集合填充DataGridView
Dictionary<String, Student> students = new Dictionary<String, Student>();
Student hat = new Student("Hathaway", "12", "Male");
Student peter = new Student("Peter","14","Male");
Student dell = new Student("Dell","16","Male");
Student anne = new Student("Anne","19","Female");
students.Add(hat.StuName,hat);
students.Add(peter.StuName,peter);
students.Add(dell.StuName,dell);
students.Add(anne.StuName,anne);
//在這里必須創建一個BindIngSource對象,用該對象接收Dictionary<>泛型集合的對象
BindingSource bs = new BindingSource();
//將泛型集合對象的值賦給BindingSourc對象的數據源
bs.DataSource = students.Values;
this.dataGridView1.DataSource = bs;
}3.3 利用SqlDataReader填充DataGridView
//使用SqlDataReader填充DataGridView
using (SqlCommand command = new SqlCommand("select * from product", DBService.Conn))
{
SqlDataReader dr = command.ExecuteReader();
BindingSource bs = new BindingSource();
bs.DataSource = dr;
this.dataGridView1.DataSource = bs;
}3.4 利用SqlDataAdapter對象向DataGridView中添加數據
using (SqlDataAdapter da = new SqlDataAdapter("select * from Product", DBService.Conn))
{
DataSet ds = new DataSet();
da.Fill(ds);
this.dataGridView1.DataSource = ds.Tables[0];
}C#是一個簡單、通用、面向對象的編程語言,它由微軟Microsoft開發,繼承了C和C++強大功能,并且去掉了一些它們的復雜特性,C#綜合了VB簡單的可視化操作和C++的高運行效率,以其強大的操作能力、優雅的語法風格、創新的語言特性和便捷的面向組件編程從而成為.NET開發的首選語言,但它不適用于編寫時間急迫或性能非常高的代碼,因為C#缺乏性能極高的應用程序所需要的關鍵功能。
看完上述內容,你們掌握怎么在C#中利用DataGridView綁定數據源的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。