資料繫結和 Windows Form

在 Windows Forms 中,您不只可以繫結至傳統的資料來源,也能繫結至幾乎任何包含資料的結構。 您可以繫結程序至執行階段計算、從檔案讀取,或衍生自其他控制項之值的值陣列。

此外,您也可以將任何控制項的任何屬性繫結至資料來源。 在傳統資料繫結中,您通常將顯示屬性 — 例如 Text 控制項的 TextBox 屬性 — 繫結到資料來源。 使用 .NET Framework,您也可以選擇透過系結來設定其他屬性。 您可以使用繫結來執行下列工作:

  • 設定影像控制項的圖形。

  • 設定一或多個控制項的背景色彩。

  • 設定控制項的大小。

基本上,資料繫結是在表單上自動設定任何控制項的任何執行階段可存取屬性的方法。

資料繫結的類型

Windows Forms 可以利用兩種類型的資料繫結:簡單繫結和複雜繫結。 各有不同的優點。

資料繫結的類型 說明
簡單資料繫結 控制項繫結至單一資料項目的能力,例如資料集中資料表的資料行值。 這是一般適用於例如 TextBox 控制項或 Label 控制項等控制項的繫結類型,這些控制項通常只會顯示單一值。 事實上,控制項上的任何屬性都可以繫結至資料庫中的欄位。 Visual Studio 的這項功能有廣泛的支援。

如需詳細資訊,請參閱

- 與資料系結相關的介面
- 如何:在 Windows Forms 中流覽資料
- 如何:在 Windows 的表單上建立 Simple-Bound 控制項
複雜資料繫結 控制項繫結至一個以上資料項目的能力,在資料庫中通常會超過一筆記錄。 複雜繫結也稱為清單架構繫結。 支援複雜繫結的控制項範例有 DataGridViewListBoxComboBox 控制項。 如需複雜資料系結的範例,請參閱如何:將 Windows Forms ComboBox 或 ListBox 控制項系結至資料

BindingSource 元件

為了簡化資料繫結,Windows Forms 可讓您將資料來源繫結至 BindingSource 元件,然後將控制項繫結至 BindingSource。 您可以在簡單或複雜繫結案例中使用 BindingSource。 在任一種情況下,BindingSource 擔任了資料來源與繫結程序控制項之間的媒介,提供變更通知流通管理和其他服務。

使用資料繫結的常見案例

幾乎所有商業應用程式都使用讀取自某種資料來源的資訊,通常是透過資料繫結。 下列清單顯示一些最常見的案例,利用資料繫結作為資料展示和管理的方法。

案例 描述
報告 報表會提供有彈性的方式,以在書面文件中顯示和彙總資料。 建立報表,將選取的資料來源內容列印至螢幕或印表機,是很常見的作法。 常見的報表包含清單、發票和摘要。 項目通常會格式化成清單資料行,且將子項目組織在每個清單項目下,但您應該選擇最適合資料的版面配置。
資料輸入 若要輸入大量相關資料,或提示使用者輸入資訊,常用的方式是透過資料輸入表單。 使用者可以輸入資訊,或使用文字方塊、選項按鈕、下拉式清單和核取方塊來選取選項。 資訊便會送出並儲存在資料庫中,其結構是根據輸入的資訊。
主從式關係 主從式應用程式是查看相關資料的一種格式。 明確地說,有兩個具有相連關係的資料表 — 在一般的商業範例中,「客戶」資料表和「訂單」資料表,它們之間連結了客戶和個別訂單的關係。 如需有關使用兩個 Windows Forms DataGridView 控制項建立主要/詳細資料應用程式的詳細資訊,請參閱如何:使用兩個 Windows Forms DataGridView 控制項建立主要/詳細表單
查閱資料表 另一個常見的資料展示/管理案例是資料表查閱。 通常,在較大的資料顯示中,ComboBox 控制項是用來顯示和管理資料。 關鍵在於 ComboBox 控制項中顯示的資料與寫入資料庫的資料不同。 例如,如果您有 ComboBox 控制項,顯示可從雜貨店取得的項目,您可能會想看到產品的名稱 (麵包、牛奶、蛋)。 不過,為了簡化資料庫中的資訊擷取以及資料庫的正規化,您可能會將特定訂單的特定項目資訊儲存為項目編號 (#501、#603 等)。 因此,表單上 ComboBox 控制項中的雜貨項目的「易記名稱」,與訂單中出現的相關項目編號,兩者之間有隱含的連接。 這是資料表查閱的本質。 如需詳細資訊,請參閱如何:使用 Windows Forms BindingSource 元件建立查閱資料表

另請參閱