定制數(shù)據(jù)視圖
成都創(chuàng)新互聯(lián)為企業(yè)級客戶提高一站式互聯(lián)網(wǎng)+設(shè)計(jì)服務(wù),主要包括成都做網(wǎng)站、網(wǎng)站制作、重慶App定制開發(fā)、重慶小程序開發(fā)、宣傳片制作、LOGO設(shè)計(jì)等,幫助客戶快速提升營銷能力和企業(yè)形象,創(chuàng)新互聯(lián)各部門都有經(jīng)驗(yàn)豐富的經(jīng)驗(yàn),可以確保每一個(gè)作品的質(zhì)量和創(chuàng)作周期,同時(shí)每年都有很多新員工加入,為我們帶來大量新的創(chuàng)意。
DataView類用來表示定制的DataTable的視圖。DataTable和DataView的關(guān)系是遵循著名的設(shè)計(jì)模式--文檔/視圖模式,其中DataTable是文檔,而Dataview是視圖。
在任何時(shí)候,你都可以有多個(gè)基于相同數(shù)據(jù)的不同的視圖。更重要的是,你可以對每一個(gè)具有自己一套屬性、方法、事件的視圖作為獨(dú)立的對象進(jìn)行處理。這也代表了相對ADO一個(gè)巨大的飛躍。
創(chuàng)建DataView
public DataView();
public DataView(DataTable);
DataView只有同已經(jīng)存在的、很可能是非空的DataTable對象連接后才可用。通常,這個(gè)連接在構(gòu)造時(shí)就指定了。
DataView dv;
dv = new DataView(theDataSet.Tables["Employees"]);
但是,你也可以先創(chuàng)建一個(gè)新的視圖,然后再用Table屬性同表相關(guān)聯(lián)。
DataView dv = new DataView();
dv.Table = theDataSet.Tables["Employees"];
DataView構(gòu)造函數(shù)使你由DataTable中得到一個(gè)DataView對象。如果需要,反之亦可。事實(shí)上,DataTable對象的DefaultView屬性返回一個(gè)該表的DataView對象。
DataView dv = dt.DefaultView;
一旦你有了DataView對象, 你可以利用它的屬性來建立你希望用戶見到的數(shù)據(jù)行集。一般,你可以使用下列屬性:
RowFilter
Sort
前者可以定制視圖中可見數(shù)據(jù)應(yīng)匹配的規(guī)則。而后者通過表達(dá)式來進(jìn)行排序。當(dāng)然你可以使用這兩者的任意組合。
設(shè)置過濾 RowFilter是一個(gè)可讀寫的屬性,用來讀取和設(shè)置表過濾的表達(dá)式。
public virtual string RowFilter {get; set;}
你可以用列名,邏輯和數(shù)字運(yùn)算符和常量的任意合法組合組成表達(dá)式。以下是一些例子:
dv.RowFilter = "Country = 'USA'";
dv.RowFilter = "EmployeeID 5 AND Birthdate #1/31/82#"
dv.RowFilter = "Description LIKE '*product*'"
讓我們來看一下過濾器的基本規(guī)則和運(yùn)算符。
過濾字符串是表達(dá)式的邏輯連接。可以用AND,OR,NOT來連接成一個(gè)較短的表達(dá)式,也可以使用圓括號來組成子句,指定優(yōu)先的運(yùn)算。
通常包含列名的子句同字母、數(shù)字、日期或另一個(gè)列名進(jìn)行比較。這里,可以使用關(guān)系運(yùn)算符和算術(shù)運(yùn)算符,如=, , , +, *, % (取模)等等。
如果要選取的行并不能方便地通過算術(shù)或邏輯運(yùn)算符表達(dá),你可以使用IN操作符。以下代碼顯示如何選取一個(gè)隨機(jī)行:
dv.RowFilter = "employeeID IN (2,4,5)"
你也可以使用通配符*和%,它們同LIKE運(yùn)算符一起使用時(shí)顯得更有用。它們都表示任意數(shù)量的字符,可以相互替代使用。
請注意,如果在LIKE子句中已經(jīng)有了*或%字符,你必須用方括號將其括起,以免歧義。如果很不幸,字符串中方括號本身也存在了,那么它也必須用將本身括起。這樣,匹配語句會(huì)如下所示:
dv.RowFilter = "Description LIKE '[[]*[]]product[[]*[]]"
通配符只允許在過濾字符串的開頭或結(jié)尾處使用,而不能在字符串中間出現(xiàn)。例如,下列語句會(huì)產(chǎn)生運(yùn)行時(shí)錯(cuò)誤:
dv.RowFilter = "Description LIKE 'prod*ct"
字符串必須以單引號括起,而日期型必須以#符號括起。字符型值可以使用小數(shù)點(diǎn)和科學(xué)計(jì)數(shù)法。
RowFilter也支持聚合函數(shù),如SUM, COUNT, MIN,MAX, and AVG。如果表中沒有數(shù)據(jù)行,那么函數(shù)將返回NULL。
在介紹RowFilter表達(dá)式的最后,讓我們討論三個(gè)很便利的函數(shù):Len,IIF和Substring。
正如其名,Len()返回特定表達(dá)式的長度。該表達(dá)式可以是一個(gè)列名,也可以是其他合法的表達(dá)式。
Substring()返回指定的表達(dá)式自特定位置開始,特定長度的字符子串。
我最喜歡用的是IIF(),它按照邏輯表達(dá)式的值有一到兩個(gè)值。IIF是IF-THEN-ELSE語句的緊湊表達(dá)。語法如下:
IIF(expression, if_true, if_false)
通 過該函數(shù),可以建立非常復(fù)雜的過濾字符串。例如,假定你從SQL Server的Northwind數(shù)據(jù)庫中取得Employees表,下列表達(dá)式可以選出那些employeeID小于6且lastname為偶數(shù)個(gè)字符 和employeeID大于6且lastname為奇數(shù)個(gè)字符的員工。
IIF(employeeID6, Len(lastname) %2 =0, Len(lastname) %2 0)
預(yù)排視圖
在上面的舉例中,datagrid必須負(fù)責(zé)預(yù)排視圖中的數(shù)據(jù)行,以便刷新用戶界面。這個(gè)自動(dòng)機(jī)制是.NET
數(shù)據(jù)綁定的產(chǎn)物。Datagrid是通過DataSource屬性來獲取數(shù)據(jù)的數(shù)據(jù)綁定控件。DataView是一個(gè)可數(shù)據(jù)綁定的類,可構(gòu)建DataSource屬性的內(nèi)容。
如果你想使用datagrid之外的另一個(gè)控件,應(yīng)該怎么辦呢?又如果你不想使用自動(dòng)數(shù)據(jù)綁定呢?應(yīng)該怎樣預(yù)排視圖中所選的數(shù)據(jù)行呢?
DataView的Table屬性指向相應(yīng)的數(shù)據(jù)表,但DataTable并不保存過濾信息。所以,預(yù)排表中的數(shù)據(jù)注定是不可行的。雖然DataTable和DataView是緊密相聯(lián)的,但它們各自保持獨(dú)立,并執(zhí)行獨(dú)立的功能。
以下Visual Basic .NET代碼段顯示了如何遍歷視圖中所有的數(shù)據(jù)行,并加入到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屬性存儲了視圖中數(shù)據(jù)行數(shù),以便在For..Next循環(huán)中使用。
要訪問視圖中某一行,可以使用DataRowView類。DataRowView可表示DataRow的視圖,就像DataView表達(dá)DataTable定制的視圖一樣。
總的來說,DataRow最多有四種狀態(tài):default,original,current和proposed。這些狀態(tài)由DataRowVersion枚舉類型設(shè)置,由RowVersion屬性表達(dá)。
DataRow的視圖只能是其中某一種狀態(tài)。
數(shù)據(jù)行的默認(rèn)(default)版本只有當(dāng)其列在構(gòu)造時(shí)設(shè)定了默認(rèn)值時(shí)才有。而初始(original)版本是指在最后一次調(diào)用表的AcceptChanges后,從數(shù)劇源中得到數(shù)據(jù)行或快照。當(dāng)前(Current)版本是指當(dāng)前的數(shù)據(jù)行,包括所有當(dāng)時(shí)發(fā)生的更新。Proposed狀態(tài)只存在于調(diào)用BeginEdit和EndEdit的編輯過程中。
可以通過訪問DataRow相同的語法訪問DataRowView。這里最重要的屬性叫Item。
排序和其他便捷的特性
DataView支持Sort屬性,可以用來對視圖中的內(nèi)容排序。Sort由用逗號分隔的列名表達(dá)式進(jìn)行排序。通過在任何列名后加ASC或者DESC限定詞,可以使得字段按照上升或者下降的順序排列。如果沒有方向限定詞,默認(rèn)順序?yàn)锳SC。
DataView是內(nèi)存中的對象,所以排序在本地進(jìn)行,無需調(diào)用數(shù)據(jù)庫服務(wù)器。
RowStateFilter是DataView另一有趣的屬性。它可以用任何預(yù)定義的標(biāo)準(zhǔn)來過濾DataTable中的內(nèi)容。下表中是DataViewRowState枚舉類型的所有取值:
CurrentRows包括所有未更新的、新的和修改的數(shù)據(jù)行Deleted所有自上次調(diào)用AcceptChanges后刪除的數(shù)據(jù)行ModifiedCurrent所有自上次調(diào)用AcceptChanges后修改過的數(shù)據(jù)行ModifiedOriginal所有自上次調(diào)用AcceptChanges后original版本的數(shù)據(jù)行New所有自上次調(diào)用AcceptChanges后新添加的行OriginalRows返回初始數(shù)據(jù)行,包含unchanged和deleted 的Unchanged所有未更新的數(shù)據(jù)行
如果要操作非連接的數(shù)據(jù),所有更新都在對DataTable調(diào)用AcceptChanges后生效。對單一行的更新在調(diào)用DataRow的AcceptChanges后生效。類似的,這些更新可以通過調(diào)用DataTable或DataRow對象的RejectChanges來取消。
DataView對象還有一些屬性,如AllowEdit,AllowDelete和AllowNew,用來得到或設(shè)定是否允許更新的值。它們的默認(rèn)值設(shè)為True,允許任何種類的更新。如果在標(biāo)志設(shè)為False時(shí),你想要完成相應(yīng)的更新操作,會(huì)有一個(gè)運(yùn)行時(shí)錯(cuò)誤發(fā)生。
DataViewManager類
DataTable對象的DefaultView屬性用來返回一個(gè)DataView對象,作為數(shù)據(jù)表中內(nèi)容的默認(rèn)視圖。它按照自然順序讀取數(shù)據(jù)并顯示表中所有的行,而不使用任何過濾。
theMasterGrid.DataSource = m_ds.Tables("Employees").DefaultView
如果需要數(shù)據(jù)特定的視圖,你可以進(jìn)行排序并/或?qū)efaultView對象直接進(jìn)行過濾。
m_ds.Tables("Employees").DefaultView.Sort = "lastname"
theMasterGrid.DataSource = m_ds.Tables("Employees").DefaultView
DataViewManager類是用來存儲DataSet中所有表的視圖設(shè)置。
可以通過傳遞一個(gè)合法的非空的DataSet給類的構(gòu)造函數(shù)來創(chuàng)建DataViewManager
Dim dvm As DataViewManager
dvm = New DataViewManager(m_ds)
也可以通過DataSet對象的DefaultViewManager屬性直接得到:
Dim dvm As DataViewManager = m_ds.DefaultViewManager
重要的是DataViewManager類是同一個(gè)DataSet相關(guān)聯(lián)的。下面是另一種可行的方法:
Dim dvm As New DataViewManager()
dvm.DataSet = m_ds
DataViewManager最重要的屬性是DataViewSettings,一個(gè)DataViewSetting對象的集合。
Dim dvs As DataViewSetting
dvs = dvm.DataViewSettings("Employees")
dvs.Sort = "lastname"
DataViewSetting對象包含了表視圖的參數(shù)信息。當(dāng)將數(shù)據(jù)綁定到對數(shù)據(jù)敏感的控件時(shí),使用DataViewManager而不是DataSet或DataTable可以保留你的視圖設(shè)置(過濾和排序字段)
theMasterGrid.DataSource = dvm
theMasterGrid.DataMember = "Employees"
在這里,視圖按照DataViewSetting中對Employees表指定的自動(dòng)進(jìn)行排序和過濾。換而言之,DataViewSetting類是對特定表的視圖的一種緩存。
dim a as string = replace(trim(textbox1.text),"TMD","") 'a 是過濾后的字符串,沒有"TMD",
還有:if textbox1.text.indexOf("TMD") -1 then exit sub
就這個(gè)之類的
Public?Class?Form1
Private?Sub?TextBox1_KeyPress(sender?As?Object,?e?As?KeyPressEventArgs)?Handles?TextBox1.KeyPress
If?Not?IsNumeric(e.KeyChar)?Then????'判斷是否為數(shù)字
e.Handled?=?True????‘如果不是數(shù)字,取消操作,不顯示字符
End?If
End?Sub
End?Class
這樣就好啦
不用這個(gè)應(yīng)該使用重載Form的ProcessCmdKey,假如我們處理的是textBox1如下: Protected Overrides Function ProcessCmdKey(ByRef msg As Message, ByVal keyData As Keys) As Boolean
If Not TextBox1.Focused Then Return False '焦點(diǎn)不在指定文本框上,不處理
If keyData = Keys.A And keyData = Keys.Z Then '是字母,還不知道是否是大小寫
If IsKeyLocked(Keys.CapsLock) Then '大寫鎖定
Return Not CInt(ModifierKeys()) And CInt(Keys.Shift) 0 '如果Shift沒鎖定(即是大寫)要過濾,返回TRUE;
Else
Return CInt(ModifierKeys()) And CInt(Keys.Shift) 0 '如果Shift鎖定(即是大寫)要過濾,返回TRUE;
End If
ElseIf keyData = Keys.Back Or keyData = Keys.Delete Then '還有允許的其它鍵
Return False
End If
Return True '剩余的鍵都過濾掉
End Function
新聞名稱:vb.net過濾英文 vba過濾器
網(wǎng)頁地址:http://chinadenli.net/article16/dogsggg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站排名、自適應(yīng)網(wǎng)站、網(wǎng)站改版、App設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)