中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ADO.NET中怎么添加數據集約束

發布時間:2021-07-23 16:26:44 來源:億速云 閱讀:142 作者:Leah 欄目:編程語言

ADO.NET中怎么添加數據集約束,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

DataAdapter 的 Fill 方法僅使用數據源中的表列和表行來填充 DataSet;雖然約束通常由數據源來設置,但在默認情況下,Fill 方法不會將此架構信息添加到 DataSet 中。 若要使用數據源中的現有主鍵約束信息填充 DataSet,則可以調用 DataAdapter 的 FillSchema 方法,或者在調用 Fill 之前將 DataAdapter 的 MissingSchemaAction 屬性設置為 AddWithKey。 這將確保 DataSet 中的主鍵約束反映數據源中的主鍵約束。 外鍵約束信息不包含在內,必須顯式創建,如ADO.NET數據集約束 (ADO.NET)中所示。

  • 如果在使用數據填充 DataSet 之前向其中添加架構信息,可以確保將主鍵約束與 DataSet 中的 DataTable 對象包含在一起。 這樣,當再次調用來填充 DataSet 時,將使用主鍵列信息將數據源中的新行與每個 DataTable 中的當前行相匹配,并使用數據源中的數據改寫表中的當前數據。 如果沒有架構信息,來自數據源的新行將追加到 DataSet 中,從而導致重復的行。

如果數據源中的某列被標識為自動遞增列,則 FillSchema 方法或 MissingSchemaAction 為 AddWithKey 的 Fill 方法將創建一個 AutoIncrement 屬性設置為 true 的 DataColumn。 不過,您將需要手動設置 AutoIncrementStep 和 AutoIncrementSeed 值。 有關自動遞增列的更多信息,請參見創建 AutoIncrement 列 (ADO.NET)。

當使用 FillSchema 或將 MissingSchemaAction 設置為 AddWithKey 時,將需要在數據源中進行額外的處理來確定主鍵列信息。 這一額外的處理可能會降低性能。 如果主鍵信息在設計時已知,為了實現***性能,建議顯式指定一個或多個主鍵列。 有關顯式設置表的主鍵信息的詳情,請參見定義主鍵 (ADO.NET)。

以下代碼示例顯示如何使用 FillSchema 向 DataSet 添加架構信息。

Dim custDataSet As DataSet = New DataSet()  custAdapter.FillSchema(custDataSet, SchemaType.Source, "Customers")  custAdapter.Fill(custDataSet, "Customers")


以下代碼示例顯示如何使用 Fill 方法的 MissingSchemaAction.AddWithKey 屬性向 DataSet 添加架構信息。

Dim custDataSet As DataSet = New DataSet()  custAdapter.MissingSchemaAction = MissingSchemaAction.AddWithKey  custAdapter.Fill(custDataSet, "Customers")

關于ADO.NET中怎么添加數據集約束問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

姚安县| 台南县| 黄冈市| 申扎县| 封开县| 保定市| 泸定县| 六安市| 比如县| 南投市| 江山市| 佛山市| 西乡县| 左云县| 浠水县| 沐川县| 子洲县| 哈密市| 赤城县| 大港区| 沿河| 涞源县| 太湖县| 邳州市| 池州市| 保定市| 论坛| 简阳市| 长泰县| 青冈县| 昭苏县| 江口县| 阿巴嘎旗| 南郑县| 湘潭县| 定襄县| 洛浦县| 临清市| 林周县| 林西县| 耒阳市|