c#中用DataView查詢

來源:互聯網
上載者:User

標籤:匹配   mysq   邏輯   ati   允許   不能   自己   語句   like   

新人菜鳥

在開發一款軟體,用到了 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時,你想要完成相應的更新操作,會有一個執行階段錯誤發生。

c#中用DataView查詢

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.