EntityFramework进阶(三)- 根据IQueryable获取DbContext
生活随笔
收集整理的這篇文章主要介紹了
EntityFramework进阶(三)- 根据IQueryable获取DbContext
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
本系列原創(chuàng)博客代碼已在EntityFramework6.0.0測(cè)試通過,轉(zhuǎn)載請(qǐng)標(biāo)明出處
有時(shí)候我們要通過IQueryable獲取所在的DbContext信息,這是完全可以的。
以下代碼從個(gè)人開源框架中抽取而出
using System; using System.Data.Entity; using System.Data.Entity.Core.Objects; using System.Data.Entity.Infrastructure; using System.Data.Entity.Infrastructure.Interception; using System.Linq; using System.Reflection;/* * CopyRight ?2017 All Rights Reserved * 作者:Rex Sheng */ namespace SuperNet.EntityFramework.Extensions {public static class IQueryableExtensions{public static DbContext GetDbContext<TEntity>(this IQueryable<TEntity> query) where TEntity : class{ObjectQuery<TEntity> objectQuery = null;DbQuery<TEntity> dbQuery = null;if(query is ObjectQuery<TEntity>){objectQuery = (ObjectQuery<TEntity>)query;}else{if(query is DbQuery<TEntity>){dbQuery = (DbQuery<TEntity>)query;var propers = dbQuery.GetType().GetProperty("InternalQuery", BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic);if (propers == null){throw new Exception("未能從IQueryable表達(dá)式找到DbContext。您確定此表達(dá)式來自Ef DbContext嗎?");}var obj = propers.GetValue(dbQuery, null);propers = obj.GetType().GetProperty("ObjectQuery", BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic);if (propers == null){throw new Exception("未能從IQueryable表達(dá)式找到DbContext。您確定此表達(dá)式來自Ef DbContext嗎?");}objectQuery = propers.GetValue(obj, null) as ObjectQuery<TEntity>;if (objectQuery == null){throw new Exception("未能從IQueryable表達(dá)式找到DbContext。您確定此表達(dá)式來自Ef DbContext嗎?");}}else{throw new Exception("未能從IQueryable表達(dá)式找到DbContext。您確定此表達(dá)式來自Ef DbContext嗎?");}}return objectQuery.Context.GetDbContext();}} }?
轉(zhuǎn)載于:https://www.cnblogs.com/RexSheng/p/10928422.html
總結(jié)
以上是生活随笔為你收集整理的EntityFramework进阶(三)- 根据IQueryable获取DbContext的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【转】时间序列分析——基于R,王燕
- 下一篇: configParser模块详谈