The EF team launched a complete set of cache and SQL Execution log solutions, efproviderwrappers. Their practice is to add a layer of packaging on the original EF provider, and use this layer of packaging interception for data caching and log monitoring. The cached data is the native data returned by the database after query, and is not an entity object. This avoids the extreme negative impact of the entity object status on the cache. In addition, this cache is transparent to upper-layer data queries, and within the same closed range, after the object type on which the cached data depends is updated (the corresponding table has a curd operation), the cache is automatically cleared. Log monitoring can be easily processed after this layer of packaging. You can download from the previous link to the original Code .
The following describes how to use it:
1. Download the source code compilation and add reference:
(1) efproviderwrappertoolkit. dll
(2) eftracingprovider. dll (used to output SQL)
(3) efcachingprovider. dll (for caching)
2. inherit an extended objectcontext from the generated objectcontext and define the required extended attributes. The focus is to redefine the constructor and generate the encapsulated entityconnection object.
Note:
(1) name = northwndentities the "northwndentities" here is the name of the connectionstring that generates EF in APP. config or web. config.
(2) "eftracingprovider", "efcachingprovider". If one is not used, delete the corresponding string.
[C-sharp] View plaincopyprint?
- Public extendednorthwindentities ()
- : This ( "name = northwindentities" )
- {
- }
- Public extendednorthwindentities ( string connectionstring)
- : base (entityconnectionwrapperutils. createentityconnectionwithwrappers (
- connectionstring,
- "eftracingprovider" ,
- "efcachingprovider"
- )
- {
- }
Public extendednorthwindentities () <br/>: This ("name = northwindentities") <br/>{< br/>}< br/> Public extendednorthwindentities (string connectionstring) <br/>: Base (entityconnectionwrapperutils. createentityconnectionwithwrappers (<br/> connectionstring, <br/> "eftracingprovider", <br/> "efcachingprovider" <br/>) <br/>{< br/>}
3. ApplicationProgramProvider:
(1) if it is a winform application, you can call the following two statements of code at application startup to register the application.[C-sharp]View plaincopyprint?
- Eftracingproviderconfiguration. registerprovider ();
- Efcachingproviderconfiguration. registerprovider ();
Eftracingproviderconfiguration. registerprovider (); <br/> efcachingproviderconfiguration. registerprovider (); <br/>
(2) For a web application, you need to append the following configuration in Web. config: (same level as the system. Web node)[XHTML]View plaincopyprint?
-
- <System. Data>
-
- <Dbproviderfactories>
- Add name = "Ef caching data provider" invariant = "efcachingprovider" description = "caching provider wrapper" type = "efcachingprovider. efcachingproviderfactory, efcachingprovider, version = 1.0.0.0, culture = neutral, publickeytoken = def642f226e0e59b " />
- Add name = "Ef tracing data provider " invariant = " eftracingprovider " description = "tracing provider wrapper" type = "eftracingprovider. eftracingproviderfactory, eftracingprovider, version = 1.0.0.0, culture = neutral, publickeytoken = def642f226e0e59b " />
- <Add Name="Ef generic provider wrapper" Invariant="Efproviderwrapper" Description="Generic provider wrapper" Type="Efproviderwrappertoolkit. efproviderwrapperfactory, efproviderwrappertoolkit, version = 1.0.0.0, culture = neutral, publickeytoken = def642f226e0e59b" />
-
- </Dbproviderfactories>
- System. data
<System. DATA> <br/> <dbproviderfactories> <br/> <Add name = "Ef caching data provider" invariant = "efcachingprovider" Description = "caching provider wrapper" type = "efcachingprovider. efcachingproviderfactory, efcachingprovider, version = 1.0.0.0, culture = neutral, publickeytoken = def642f226e0e59b "/> <br/> <Add name =" Ef tracing data provider "invariant =" eftracingprovider "Description =" tracing provider wrapper "type =" eftracingprovider. eftracingproviderfactory, eftracingprovider, version = 1.0.0.0, culture = neutral, publickeytoken = Taobao "/> <br/> <Add name =" Ef generic provider wrapper "invariant =" efproviderwrapper "Description =" generic provider wrapper "type =" efproviderwrappertoolkit. efproviderwrapperfactory, efproviderwrappertoolkit, version = 1.0.0.0, culture = neutral, publickeytoken = def642f226e0e59b "/> <br/> </dbproviderfactories> <br/> </system. DATA> <br/>
How to append log4net output:
According to the above steps, some code is added to the extension class of objectcontext. For details, see the comments in the Code:[C-sharp]View plaincopyprint?
-
- PublicPartialClassExtendednorthwindentities: northwndentities
-
- {
-
- Private StaticIlog logger;
-
- StaticExtendednorthwindentities ()
-
- {
-
- // Register tracingprovider
-
- Eftracingproviderconfiguration. registerprovider ();
- // Initialize log4net and configure it in the independent "log4net. config"
-
- Log4net. config. xmlconfigurator. Configure (NewFileinfo ("Log4net. config"));
-
- // Initialize a logger
-
- Logger = log4net. logmanager. getlogger ("Eflog4net");
-
- }
-
- PublicExtendednorthwindentities ()
-
- :This("Name = northwndentities")
-
- {
- // Bind the commandexecuting event of eftracingconnection and output the log
-
- This. Unwrapconnection <eftracingconnection> (). commandexecuting + = (S, e) =>
-
- {
-
- // Output tracestring (SQL)
-
- Logger. debug (environment. newline + E. totracestring (). trimend ());
-
- };
-
- }
-
- PublicExtendednorthwindentities (StringConnectionstring)
-
- :Base(Entityconnectionwrapperutils. createentityconnectionwithwrappers (
- Connectionstring,
-
- "Eftracingprovider"
-
- ))
-
- {
-
- }
Public partial class extendednorthwindentities: northwndentities <br/>{< br/> Private Static ilog logger; <br/> static extendednorthwindentities () <br/>{< br/> // register tracingprovider <br/> eftracingproviderconfiguration. registerprovider (); <br/> // initialize log4net, Which is configured in an independent "log4net. config ". <br/> log4net. config. xmlconfigurator. configure (New fileinfo ("log4net. config "); <br/> // initialize a logger <br/> logger = log4net. logmanager. getlogger ("eflog4net"); <br/>}< br/> Public extendednorthwindentities () <br/>: This ("name = northwndentities ") <br/>{< br/> // bind the commandexecuting event of eftracingconnection, and output log <br/> This. unwrapconnection <eftracingconnection> (). commandexecuting + = (S, e) => <br/>{< br/> // output tracestring (SQL) <br/> logger. debug (environment. newline + E. totracestring (). trimend (); <br/>}; <br/>}< br/> Public extendednorthwindentities (string connectionstring) <br/>: Base (entityconnectionwrapperutils. createentityconnectionwithwrappers (<br/> connectionstring, <br/> "eftracingprovider" <br/>) <br/>{< br/>}< br/>}
The configuration of log4net. config is as follows: (for other detailed configuration instructions of log4net, refer to the http://logging.apache.org/log4net/release/config-examples.html) [C-sharp] View plaincopyprint?
-
- <? XML version ="1.0"Encoding ="UTF-8"?>
-
- <Configuration>
-
- <Log4net>
-
- <Root>
-
- <Level value ="All"/>
-
- <Appender-Ref Ref="Rollingfileappender"/>
- <Appender-Ref Ref="Leleappender"/>
-
- </Root>
-
- <Appender name ="Rollingfileappender"Type ="Log4net. appender. rollingfileappender, log4net">
-
- <Param name ="File"Value =Http://www.cnblogs.com/logs/EFLogs.txt"/>
-
- <Param name ="Appendtofile"Value ="True"/>
- <Param name ="Rollingstyle"Value ="Date"/>
-
- <Param name ="Datepattern"Value ="YYYY. Mm. dd"/>
-
- <Param name ="Staticlogfilename"Value ="True"/>
-
- <Layout type ="Log4net. layout. patternlayout, log4net">
-
- <Param name ="Conversionpattern"Value ="% D [% T] %-5 p % C-% m % N"/>
-
- </Layout>
-
- </Appender>
- <Appender name ="Leleappender"Type ="Log4net. appender. coloredconsoleappender, log4net">
-
- <Mapping>
-
- <Level value ="Debug"/>
-
- <! -- <Forecolor value ="White"/> -->
-
- <Backcolor value ="Cyan, highintensity"/>
-
- </Mapping>
-
- <Layout type ="Log4net. layout. patternlayout, log4net">
- <Param name ="Conversionpattern"Value ="% D [% T] [%-5 p] % C-% m % N"/>
-
- </Layout>
-
- </Appender>
-
- </Log4net>
-
- </Configuration>
<? XML version = "1.0" encoding = "UTF-8"?> <Br/> <configuration> <br/> <log4net> <br/> <root> <br/> <level value = "all"/> <br/> <appender -Ref ref = "rollingfileappender"/> <br/> <appender-ref = "leleappender"/> <br/> </root> <br/> <appender name = "rollingfileappender" type = "log4net. appender. rollingfileappender, log4net "> <br/> <Param name =" file "value =" http://www.cnblogs.com/logs/EFLogs.txt "/> <br/> <Param name =" appendtofile "value =" Tru E "/> <br/> <Param name =" rollingstyle "value =" date "/> <br/> <Param name =" datepattern "value =" YYYY. mm. dd "/> <br/> <Param name =" staticlogfilename "value =" true "/> <br/> <layout type =" log4net. layout. patternlayout, log4net "> <br/> <Param name =" conversionpattern "value =" % d [% T] %-5 p % C-% m % N "/> <br/> </layout> <br/> </appender> <br/> <appender name = "leleappender" type = "log4net. appender. coloredcon Soleappender, log4net "> <br/> <mapping> <br/> <level value =" debug "/> <br/> <! -- <Forecolor value = "white"/> --> <br/> <backcolor value = "cyan, highintensity "/> <br/> </mapping> <br/> <layout type =" log4net. layout. patternlayout, log4net "> <br/> <Param name =" conversionpattern "value =" % d [% T] [%-5 p] % C-% m % N "/> <br/> </layout> <br/> </appender> <br/> </log4net> <br/> </configuration>
In this way, you can control the SQL output generated by EF through the log4net configuration file. In the above log4net, two appender are configured. One is output to the console, and the other is output to eflogs.txt.
Next, call EF to see the output log:[C-sharp]View plaincopyprint?
-
- Static VoidMain (String[] ARGs)
-
- {
-
- Using(Var db =NewExtendednorthwindentities ())
-
- {
-
- VaR toyproducts = from PInDB. Products
-
- Where p. Category. categoryname. Contains ("Seafood")
- SelectNew{P. Category. categoryname, P. productname, P. unitprice };
-
- Console. writeline ("-----------------");
-
- Foreach(VAR PInToyproducts)
-
- Console. writeline ("{0,-10} {1,-35} {2, 10 }", P. categoryname, P. productname, P. unitprice );
-
- }
-
- Console. Read ();
-
- }
Static void main (string [] ARGs) <br/>{< br/> using (var db = new extendednorthwindentities ()) <br/> {<br/> var toyproducts = from P in dB. products <br/> where p. category. categoryname. contains ("seafood") <br/> select new {P. category. categoryname, P. productname, P. unitprice }; <br/> console. writeline ("-----------------"); <br/> foreach (var p in toyproducts) <br/> console. writeline ("{0,-10} {1,-35} {2, 10}", p. categoryname, P. productname, P. unitprice); <br/>}< br/> console. read (); <br/>}
the output in the blue background above is the SQL log configured and output through log4net. In addition, this efproviderwrappers not only allows us to output log functions, but also provides important functions for its caching, in the next Article , I will focus on how to use efproviderwrappers to implement data caching.