c#中用DataView查詢

来源:http://www.cnblogs.com/Lbox/archive/2017/07/07/7134075.html
-Advertisement-
Play Games

新人菜鳥 在開發一款軟體,用到了 MyS中的 DataView 查詢。查詢後判斷視圖是否有返回值,找了好久,終於找到了他的 DataView XX.Count 參數。 原文網址:http://skybirdzw.blog.163.com/blog/static/7257062620112334552 ...


新人菜鳥

在開發一款軟體,用到了 MyS中的 DataView 查詢。查詢後判斷視圖是否有返回值,找了好久,終於找到了他的 DataView XX.Count 參數。

 string table = String.Format("`Database` WHERE `XX` = '{0}';", XX);                    
                    DataView dv = mysqlUtile.MysqlDataAdapter(table);

                    if (dv.Count==0)
	                    {
                           ...                 
	                    }
                }

  

 

 

原文網址:http://skybirdzw.blog.163.com/blog/static/725706262011233455240/

DataView類用來表示定製的DataTable的視圖。DataTableDataView的關係是遵循著名的設計模式--文檔/視圖模式,其中DataTable是文檔,而Dataview是視圖。
在任何時候,你都可以有多個基於相同數據的不同的視圖。更重要的是,你可以對每一個具有自己一套屬性、方法、事件的視圖作為獨立的對象進行處理。這也代表了相對ADO一個巨大的飛躍。
創建DataView

public DataView();
public DataView(DataTable);

DataView只有同已經存在的、很可能是非空的DataTable對象連接後才可用。通常,這個連接在構造時就指定了。

DataView dv;
dv = new DataView(theDataSet.Tables["Employees"]);

 但是,你也可以先創建一個新的視圖,然後再用Table屬性同表相關聯。

DataView dv = new DataView();
dv.Table = theDataSet.Tables["Employees"];
DataView構造函數使你由DataTable中得到一個DataView對象。如果需要,反之亦可。事實上,DataTable對象的DefaultView屬性返回一個該表的DataView對象。
DataView dv = dt.DefaultView;


一旦你有了DataView對象,你可以利用它的屬性來建立你希望用戶見到的數據行集。一般,你可以使用下列屬性:

  • RowFilter
  • Sort

前者可以定製視圖中可見數據應匹配的規則。而後者通過表達式來進行排序。當然你可以使用這兩者的任意組合。

設置過濾 RowFilter是一個可讀寫的屬性,用來讀取和設置表過濾的表達式。

public virtual string RowFilter {get; set;}

 你可以用列名,邏輯和數字運算符和常量的任意合法組合組成表達式。以下是一些例子:

dv.RowFilter = "Country = 'USA'";
dv.RowFilter = "EmployeeID >5 AND Birthdate < #1/31/82#"
dv.RowFilter = "Description LIKE '*product*'"


讓我們來看一下過濾器的基本規則和運算符。
過濾字元串是表達式的邏輯連接。可以用AND,OR,NOT來連接成一個較短的表達式,也可以使用圓括弧來組成子句,指定優先的運算。
通常包含列名的子句同字母、數字、日期或另一個列名進行比較。這裡,可以使用關係運算符和算術運算符,如>=, <, >, +, *, % (取模)等等。
如果要選取的行並不能方便地通過算術或邏輯運算符表達,你可以使用IN操作符。以下代碼顯示如何選取一個隨機行:

dv.RowFilter = "employeeID IN (2,4,5)"


你也可以使用通配符*和%,它們同LIKE運算符一起使用時顯得更有用。它們都表示任意數量的字元,可以相互替代使用。
請註意,如果在LIKE子句中已經有了*或%字元,你必須用方括弧將其括起,以免歧義。如果很不幸,字元串中方括弧本身也存在了,那麼它也必須用將本身括起。這樣,匹配語句會如下所示:

dv.RowFilter = "Description LIKE '[[]*[]]product[[]*[]]"


通配符只允許在過濾字元串的開頭或結尾處使用,而不能在字元串中間出現。例如,下列語句會產生運行時錯誤:

dv.RowFilter = "Description LIKE 'prod*ct"


字元串必須以單引號括起,而日期型必須以#符號括起。字元型值可以使用小數點和科學計數法。
RowFilter也支持聚合函數,如SUM, COUNT, MIN,MAX, and AVG。如果表中沒有數據行,那麼函數將返回NULL。
在介紹RowFilter表達式的最後,讓我們討論三個很便利的函數:Len,IIF和Substring。
正如其名,Len()返回特定表達式的長度。該表達式可以是一個列名,也可以是其他合法的表達式。
Substring()返回指定的表達式自特定位置開始,特定長度的字元子串。
我最喜歡用的是IIF(),它按照邏輯表達式的值有一到兩個值。IIF是IF-THEN-ELSE語句的緊湊表達。語法如下:

IIF(expression, if_true, if_false)


通 過該函數,可以建立非常複雜的過濾字元串。例如,假定你從SQL Server的Northwind資料庫中取得Employees表,下列表達式可以選出那些employeeID小於6且lastname為偶數個字元和employeeID大於6且lastname為奇數個字元的員工。

IIF(employeeID<6, Len(lastname) %2 =0, Len(lastname) %2 >0)

預排視圖
在上面的舉例中,datagrid必須負責預排視圖中的數據行,以便刷新用戶界面。這個自動機制是.NET
數據綁定的產物。Datagrid是通過DataSource屬性來獲取數據的數據綁定控制項。DataView是一個可數據綁定的類,可構建DataSource屬性的內容。

如果你想使用datagrid之外的另一個控制項,應該怎麼辦呢?又如果你不想使用自動數據綁定呢?應該怎樣預排視圖中所選的數據行呢?

DataView的Table屬性指向相應的數據表,但DataTable並不保存過濾信息。所以,預排表中的數據註定是不可行的。雖然DataTableDataView是緊密相聯的,但它們各自保持獨立,並執行獨立的功能。
以下Visual Basic .NET代碼段顯示瞭如何遍歷視圖中所有的數據行,並加入到listbox中。

Dim dv As New DataView()
dv = ds.Tables("Employees").DefaultView
dv.RowFilter = "employeeid >5"

ListBox1.Items.Clear()
Dim buf As String
Dim dr As DataRowView
For Each dr In dv
buf = ""
buf &= dr("lastname").ToString()& ", " & dr("firstName").ToString()
ListBox1.Items.Add(buf)
Next


正如前面說提到的,DataView是可枚舉的類,因此你可以安全的將它傳給For..Each語句。Count屬性存儲了視圖中數據行數,以便在For..Next迴圈中使用。
要訪問視圖中某一行,可以使用DataRowView類。DataRowView可表示DataRow的視圖,就像DataView表達DataTable定製的視圖一樣。
總的來說,DataRow最多有四種狀態:default,original,current和proposed。這些狀態由DataRowVersion枚舉類型設置,由RowVersion屬性表達。
DataRow的視圖只能是其中某一種狀態。
數據行的預設(default)版本只有當其列在構造時設定了預設值時才有。而初始(original)版本是指在最後一次調用表的AcceptChanges後,從數劇源中得到數據行或快照。當前(Current)版本是指當前的數據行,包括所有當時發生的更新。Proposed狀態只存在於調用BeginEdit和EndEdit的編輯過程中。
可以通過訪問DataRow相同的語法訪問DataRowView。這裡最重要的屬性叫Item。

排序和其他便捷的特性
DataView支持Sort屬性,可以用來對視圖中的內容排序。Sort由用逗號分隔的列名錶達式進行排序。通過在任何列名後加ASC或者DESC限定詞,可以使得欄位按照上升或者下降的順序排列。如果沒有方向限定詞,預設順序為ASC。
DataView是記憶體中的對象,所以排序在本地進行,無需調用資料庫伺服器。
RowStateFilter是DataView另一有趣的屬性。它可以用任何預定義的標準來過濾DataTable中的內容。下表中是DataViewRowState枚舉類型的所有取值:

CurrentRows 包括所有未更新的、新的和修改的數據行
Deleted 所有自上次調用AcceptChanges後刪除的數據行
ModifiedCurrent 所有自上次調用AcceptChanges後修改過的數據行
ModifiedOriginal 所有自上次調用AcceptChanges後original版本的數據行
New 所有自上次調用AcceptChanges後新添加的行
OriginalRows 返回初始數據行,包含unchanged和deleted 的
Unchanged 所有未更新的數據行


如果要操作非連接的數據,所有更新都在對DataTable調用AcceptChanges後生效。對單一行的更新在調用DataRowAcceptChanges後生效。類似的,這些更新可以通過調用DataTableDataRow對象的RejectChanges來取消。
DataView對象還有一些屬性,如AllowEdit,AllowDeleteAllowNew,用來得到或設定是否允許更新的值。它們的預設值設為True,允許任何種類的更新。如果在標誌設為False時,你想要完成相應的更新操作,會有一個運行時錯誤發生。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 美國國家安全局(NSA)旗下的“方程式黑客組織”(shadow brokers)使用的部分網路武器被公開,其中包括可以遠程攻破全球約70%Windows機器的漏洞利用工具。 其中,有十款工具最容易影響Windows個人用戶,包括永恆之藍、永恆王者、永恆浪漫、永恆協作、翡翠纖維、古怪地鼠、愛斯基摩捲、 ...
  • 本文為命令ssh的man文檔翻譯,翻譯了90%的內容,剩餘是一些沒必要翻譯的東西,請見諒。 如此文有所疑惑,希望我的另一篇文章能解惑:http://www.cnblogs.com/f-ck-need-u/p/7129122.html SSH(1) BSD General Commands Manua ...
  • 超線程和多線程的區別? 在Linux系統中,如何詳細瞭解CPU的信息呢? 當然是通過cat /proc/cpuinfo來檢查了,但是比如幾個物理CPU/幾核/幾線程,這些問題怎麼確定呢? 經過查看,我的開發機器是1個物理CPU,4核8線程,Intel(R) Core(TM) i7 CPU 860 @ ...
  • 巡檢發現一臺Linux伺服器上的作業沒有如期發送郵件,登錄伺服器檢查後發現作業並沒有執行,於是檢查一下crontab的設置。結果發現如下錯誤: [root@mylnx2 ~]# crontab -l Authentication token is no longer valid; new one r ...
  • 網盤視頻:裡面包含了centos,ubuntu,Solaris 三種目前比較主流的操作系統的安裝,以及他們的開發環境的安裝 https://pan.baidu.com/disk/home#list/vmode=list&path=%2FC%2B%2B%2F%E7%AC%AC%E4%B8%80%E9% ...
  • Spring Batch是一個輕量級的,完全面向Spring的批處理框架,可以應用於企業級大量的數據處理系統。Spring Batch以POJO和大家熟知的Spring框架為基礎,使開發者更容易的訪問和利用企業級服務。Spring Batch可以提供大量的,可重覆的數據處理功能,包括日誌記錄/跟蹤, ...
  • 一:共用賬號檢查 二:來賓賬戶檢查 三:口令複雜度策略 四:口令最長生存期策略 五:遠程關機授權 六:系統關閉授權 七:文件許可權指派 八:匿名許可權限制 八:登陸日誌檢查 九:系統日誌完備性檢查 十:日誌大小設置 十一:遠程登錄超時配置 十二:預設共用檢查 十三:共用許可權檢查 十四:防範病毒管理 十五 ...
  • 之前在公司用的服務端是wcf寫的,但是沒有深入研究,最近找工作,面試的時候好多人看到這個總提問,這裡做個複習 就用微軟官方上的例子,搭一個簡單的wcf服務,分6步 1 定義服務協定也就是契約,其實就是定義一個服務介面,這玩意後邊是公開客戶端用的,然後也告訴後邊承載程式應該如何載入服務 主要涉及兩個特 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...