您好,登錄后才能下訂單哦!
這篇文章主要介紹“Linq Tracking Changes機(jī)制有什么作用”,在日常操作中,相信很多人在Linq Tracking Changes機(jī)制有什么作用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Linq Tracking Changes機(jī)制有什么作用”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
Linq Tracking Changes機(jī)制
OK,我們能夠順利的由WCF Service取得資料,那么接下來的更新動作該如何做呢?,照MSDN中『順帶一提』的說明中,要于N-Tier情況下實作更新功能必須視UI層而定,于ASP.NET中可透過ObjectDataSource 控件的協(xié)助完成,但在WPF、Windows Form中,程式設(shè)計師則必須自行實作Client端的Linq Tracking Changes機(jī)制。
那什么是Linq Tracking Changes機(jī)制呢?簡單的說,更新一筆資料需要有兩個資訊,一是Entity Object的現(xiàn)值,一則是Entity Object的原始值,在更新資料時,我們必須將這兩個資訊送達(dá)WCF Service,然后由WCF Service依據(jù)原值來取得欲更新的資料列后,將現(xiàn)值更新進(jìn)去。
問題在,LINQ To SQL Designer只是將Entity Class標(biāo)示為可序列化,并未產(chǎn)生出任何的Tracking Changes所需要的程式碼,這也就是說!在WPF端時,我們必須于資料列更新時,將原值先記錄下來,否則就無法透過WCF Service來更新該筆資料了。更確切的說,就是少了一個類似DataSet之GetChanges函式的機(jī)制。
那該如何實作這個機(jī)制呢?很幸運(yùn)的,LINQ To SQL Designer所產(chǎn)生出的Entity Class實作了INotifyPropertyChanging介面,因此我們可掛載事件至其所定義的PropertyChanging事件中,于物件屬性值改變時,事先將原值記錄下來,完成Linq Tracking Changes機(jī)制。但也很不幸的,透過WCF Service所產(chǎn)生的Proxy Class忽略了此介面,并沒有產(chǎn)生出對應(yīng)的程式碼,所以透過INotifyPropertyChanging介面來實作Tracking Changes的想法是不可能達(dá)到的。
退而求其次,我們只能以Context的概念來實作Tracking Changes,也就是說于取得物件的同時,將所有物件復(fù)制一份,將原值保留下來,然后透過另一介面INotifyPropertyChanged來偵測物件是否已被改變。
using System; using System.ComponentModel; using System.Collections.Generic; using System.Linq; using System.Text; using System.Reflection; namespace WpfDataConsumer { public class TrackingContext<T,TUpdate> { ……………. public void Initialize(IList<T> objs) { _states.Clear(); _update_original = typeof(TUpdate).GetProperty("Original"); _update_current = typeof(TUpdate).GetProperty("Current"); _update_state = typeof(TUpdate).GetProperty("State"); foreach (T item in objs) { object updateData = Activator.CreateInstance(typeof(TUpdate), false); _update_original.SetValue(updateData, CloneObject(item),null); _update_current.SetValue(updateData, item, null); _update_state.SetValue(updateData, WpfDataConsumer.DataService.UpdateState.UnChanged, null); ((INotifyPropertyChanged)item).PropertyChanged += new PropertyChangedEventHandler(TrackingContext_PropertyChanged); _states.Add(item, (TUpdate)updateData); } } void TrackingContext_PropertyChanged(object sender, PropertyChangedEventArgs e) { if (_states.ContainsKey((T)sender)) { object o = _states[(T)sender]; DataService.UpdateState state = (DataService.UpdateState)_update_state.GetValue(o, null); if (state == WpfDataConsumer.DataService.UpdateState.Insert) return; _update_state.SetValue(o, WpfDataConsumer.DataService.UpdateState.Update, null); } } } }
有了Linq Tracking Changes機(jī)制的協(xié)助后,WCF Service端可以獲得欲更新資料物件的原值與現(xiàn)值,要更新資料就不難了。
到此,關(guān)于“Linq Tracking Changes機(jī)制有什么作用”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。