Asp.net core利用dynamic簡(jiǎn)化數(shù)據(jù)庫(kù)訪問(wèn)
今天寫(xiě)了一個(gè)數(shù)據(jù)庫(kù)的幫助類(lèi),代碼如下。
public static class DbEx
{
public static dynamic ReadToObject(this IDataReader reader)
{
var obj = new DbObject();
for (int i = 0; i < reader.FieldCount; i++)
{
obj[reader.GetName(i)] = new DbField()
{
DbData = reader[i]
};
}
return obj;
}
public class DbObject : DynamicObject
{
//自己實(shí)現(xiàn)一個(gè),不用ExpandoObject, 以支持無(wú)視大小寫(xiě)讀取
public override bool TryGetMember(GetMemberBinder binder, out object result)
{
result = this[binder.Name];
return true;
}
Dictionary<string, object> _values = new Dictionary<string, object>(StringComparer.CurrentCultureIgnoreCase);
public object this[string index]
{
get => _values[index];
set => _values[index] = value;
}
}
public class DbField
{
public object DbData { get; set; }
public T Value<T>()
{
return (T)Convert.ChangeType(DbData, typeof(T));
}
public static implicit operator string(DbField data) => data.Value<string>();
public static implicit operator int(DbField data) => data.Value<int>();
public static implicit operator DateTime(DbField data) => data.Value<DateTime>();
public static implicit operator double(DbField data) => data.Value<double>();
public static implicit operator bool(DbField data) => data.Value<bool>();
}
}簡(jiǎn)單的來(lái)講,可以把如下代碼
GpsData parse(IDataReader reader)
{
return new GpsData()
{
IsValid = (bool)reader["IsValid"],
Location = new Location ()
{
Lon = (double)reader["Lon"],
Lat = (double)reader["Lat"],
},
Angle = (double)reader["Angle"],
Speed = (double)reader["Speed"]),
UpdateTime = (double)reader["Speed"]),
};
}轉(zhuǎn)換為如下形式
GpsData parse(IDataReader reader)
{
var obj = reader.ReadToObject();
var state = new GpsData()
{
IsValid = obj.IsValid,
Location = new Location()
{
Lon = obj.Lon,
Lat = obj.Lat,
},
Angle = obj.Angle,
Speed = obj.Speed,
UpdateTime = obj.UpdateTime,
};
return state;
}到此這篇關(guān)于Asp.net core利用dynamic簡(jiǎn)化數(shù)據(jù)庫(kù)訪問(wèn)的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- ASP.NET?Core使用EF為關(guān)系數(shù)據(jù)庫(kù)建模
- ASP.NET?Core基于現(xiàn)有數(shù)據(jù)庫(kù)創(chuàng)建EF模型
- .NET?Core配置連接字符串和獲取數(shù)據(jù)庫(kù)上下文實(shí)例
- .NET Core使用EF生成數(shù)據(jù)庫(kù)出錯(cuò)的解決方法
- ASP.NET?Core使用EF?SQLite對(duì)數(shù)據(jù)庫(kù)增刪改查
- .Net Core 使用NLog記錄日志到文件和數(shù)據(jù)庫(kù)的操作方法
- EFCore 通過(guò)實(shí)體Model生成創(chuàng)建SQL Server數(shù)據(jù)庫(kù)表腳本
- .net core下配置訪問(wèn)數(shù)據(jù)庫(kù)操作
相關(guān)文章
CheckBox控件默認(rèn)選中,提交時(shí)永遠(yuǎn)獲得選中狀態(tài)的實(shí)現(xiàn)代碼
下面小編就為大家?guī)?lái)一篇CheckBox控件默認(rèn)選中,提交時(shí)永遠(yuǎn)獲得選中狀態(tài)的實(shí)現(xiàn)代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05
一個(gè)伴隨ASP.NET從1.0到4.0的OutputCache Bug介紹
一個(gè)伴隨ASP.NET從1.0到4.0的OutputCache Bug介紹,學(xué)習(xí).net的朋友可以參考下。2011-11-11
Asp.net基于ajax和jquery-ui實(shí)現(xiàn)進(jìn)度條
這篇文章主要介紹了Asp.net基于ajax和jquery-ui實(shí)現(xiàn)進(jìn)度條,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12
ASP.NET 連接ACCESS數(shù)據(jù)庫(kù)的簡(jiǎn)單方法
一段非常簡(jiǎn)單的連接ACCESS數(shù)據(jù)庫(kù)的實(shí)例代碼,有需要的朋友可以參考一下2013-07-07
.Net項(xiàng)目在Docker容器中開(kāi)發(fā)部署
這篇文章介紹了.Net項(xiàng)目在Docker容器中開(kāi)發(fā)部署的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
ASP.NET預(yù)備知識(shí)學(xué)習(xí)筆記
這篇文章主要介紹了ASP.NET預(yù)備知識(shí),內(nèi)容很全面,幾乎涵蓋了asp.net預(yù)備知識(shí)點(diǎn),感興趣的小朋友可以看一看。2015-09-09
ASP.NET文件上傳Upload的實(shí)現(xiàn)方法
這篇文章主要為大家詳細(xì)介紹了ASP.NET文件上傳的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11

