CN.Text开发笔记—利用反射将数据读入实体类
在實(shí)際開發(fā)中,我們經(jīng)常需要從數(shù)據(jù)庫中讀取數(shù)據(jù)并賦值給實(shí)體類的相應(yīng)屬性。在.Text的DataDTOProvider中存在大量這樣的代碼, 比如:
????????{
????????????System.Collections.ArrayList?al=new?System.Collections.ArrayList();
????????????IDataReader?reader=DbProvider.Instance().GetRoles(BlogID);
????????????try
????????????{
????????????????while(reader.Read())
????????????????{
????????????????????Role?role=new?Role();
????????????????????if(reader["RoleID"]!=DBNull.Value)
????????????????????{
????????????????????????role.RoleID=(int)reader["RoleID"];
????????????????????}
????????????????????if(reader["Name"]!=DBNull.Value)
????????????????????{
????????????????????????role.Name=(string)reader["Name"];
????????????????????}
????????????????????if(reader["Description"]!=DBNull.Value)
????????????????????{
????????????????????????role.Description=(string)reader["Description"];
????????????????????}
????????????????????//ReaderToObject(reader,role);
????????????????????al.Add(role);
????????????????}
????????????}
????????????finally
????????????{
????????????????reader.Close();
????????????}
????????????return?(Role[])al.ToArray(typeof(Role));
????????
????????}
對于上面的代碼,我覺得有幾點(diǎn)不優(yōu)雅之處:
1、每次對Role的屬性進(jìn)行賦值時(shí),都要檢查reader的值是否為DBNull,出現(xiàn)了很多重復(fù)代碼
2、每次對Role的屬性進(jìn)行賦值時(shí),都要進(jìn)行類型轉(zhuǎn)換, 而Role屬性的類型是已知的,是不是可以自動(dòng)完成這樣的轉(zhuǎn)換?
3、每次對Role的屬性進(jìn)行賦值時(shí),都要進(jìn)行Role屬性與數(shù)據(jù)庫字段的對應(yīng)。如果我們在設(shè)計(jì)數(shù)據(jù)庫與實(shí)體類時(shí),保證數(shù)據(jù)庫字段與實(shí)體類屬性采用同樣的名稱,那利用反射,我們可以通過代碼自動(dòng)進(jìn)行屬性與字段的對應(yīng)。即使數(shù)據(jù)庫字段與屬性不同名,我們也可以通過更改查詢語句,來做到這一點(diǎn)。
是不是可以對上面的代碼進(jìn)行改進(jìn),使代碼變得更優(yōu)雅?那優(yōu)雅的代碼應(yīng)該是什么樣的呢?如果我們用上面代碼中注釋的代碼行ReaderToObject(reader,role);取代它之前的對Role屬性進(jìn)行賦值的語句,是不是會(huì)使代碼變得更優(yōu)雅?ReaderToObject的作用就是自動(dòng)完成將reader中的值寫入到role中對應(yīng)的屬性中(前提是reader中的字段與role中對應(yīng)的屬性具有相同的名稱)?,F(xiàn)在我們的任務(wù)就是實(shí)現(xiàn)ReaderToObject, 有了強(qiáng)大的武器—Reflection,我們的任務(wù)就變得很輕松, 也不多說了,下面的代碼是我的實(shí)現(xiàn)方法:
????????{
????????????for(int?i=0;i<reader.FieldCount;i++)
????????????{
????????????????System.Reflection.PropertyInfo?propertyInfo=targetObj.GetType().GetProperty(reader.GetName(i));
????????????????if(propertyInfo!=null)
????????????????{
????????????????????if(reader.GetValue(i)!=DBNull.Value)
????????????????????{
????????????????????????propertyInfo.SetValue(targetObj,reader.GetValue(i),null);
????????????????????}
????????????????}
????????????}
????????}
ReaderToObject可以將reader中的數(shù)據(jù)讀入到任何實(shí)體類中。數(shù)據(jù)庫字段與實(shí)體類屬性的映射原則是名稱相同。當(dāng)然,我們也可以通過配置文件來進(jìn)行兩者映射。
????個(gè)人想法:在開發(fā)中,面對那么多設(shè)計(jì)思想和設(shè)計(jì)模式,常常令人感到迷惑,當(dāng)你把更多的精力放在選用哪個(gè)設(shè)計(jì)思想或設(shè)計(jì)模式時(shí),我覺得不要忽略很重要的一點(diǎn),盡可能地減少重復(fù)代碼,只要我們能有效地減少重復(fù)代碼,我們采用的方法就是好方法,而不要太在乎采用了哪種模式。就像獨(dú)孤九劍,正因?yàn)閿[脫了傳統(tǒng)招式的束縛,才能戰(zhàn)無不勝!
總結(jié)
以上是生活随笔為你收集整理的CN.Text开发笔记—利用反射将数据读入实体类的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。