当前位置: 首页 > news >正文

网站平台搭建流程微信营销教程

网站平台搭建流程,微信营销教程,企业网站小程序源码,网站建设建站前言 上节我们留了一个问题,为什么EF Core中,我们加载班级,数据并不会出来 其实答案很简单,~ 因为在EF Core1.1.2 中我们在EF6.0中用到的的延迟加载功能并没有被加入,不过在EF Core 2.0中,这个功能将回归 而且这个功能是否需要被加入进去,社区也在激烈的讨论当中,有兴趣的可…前言 上节我们留了一个问题,为什么EF Core中,我们加载班级,数据并不会出来 其实答案很简单,~ 因为在EF Core1.1.2 中我们在EF6.0中用到的的延迟加载功能并没有被加入,不过在EF Core 2.0中,这个功能将回归 而且这个功能是否需要被加入进去,社区也在激烈的讨论当中,有兴趣的可以去看看: https://github.com/aspnet/EntityFramework/issues/3797 那么我们该如何加载关联的班级呢?. 直接通过Linq join当然是可以的. 我们也可以通过贪婪加载来获取,修改查询代码如下: public IActionResult ListView(){ return View(_context.UserTable.Include(aa.Class).ToList());} 效果如下: 下面我们开始今天的内容  事务 关于EF Core的事务,其实与EF 6.x几乎一样,代码如下: using (var tran _context.Database.BeginTransaction()){ try{_context.ClassTable.Add(new ClassTable { ClassName AAAAA, ClassLevel 2 });_context.ClassTable.Add(new ClassTable { ClassName BBBBB, ClassLevel 2 });_context.SaveChanges(); throw new Exception(模拟异常);tran.Commit();} catch (Exception){tran.Rollback(); // TODO: Handle failure}} 在异常中Rollback即可回滚,我这里的写法,其实有点无耻. 不过目的是告诉大家,要在Commit之前回滚. 不然会得到一个异常:This SqlTransaction has completed; it is no longer usable.” 下面我们来讲一下关于EF Core中的日志 日志 我们知道,在ASP.NET Core中,大量的使用了IOC的手法来注入我们所需要的类. EF Core其实也一样,. 首先我们需要创建一个EF日志类,继承Microsoft.Extensions.Logging.ILogger 如下: private class EFLogger : ILogger{ private readonly string categoryName; public EFLogger(string categoryName) this.categoryName categoryName; public bool IsEnabled(LogLevel logLevel){ return true;} public void LogTState(LogLevel logLevel, EventId eventId, TState state, Exception exception, FuncTState, Exception, string formatter){Debug.WriteLine($时间:{DateTime.Now.ToString(o)} 日志级别: {logLevel} {eventId.Id} 产生的类{this.categoryName});DbCommandLogData data state as DbCommandLogData;Debug.WriteLine($SQL语句:{data.CommandText},\n 执行消耗时间:{data.ElapsedMilliseconds});} public IDisposable BeginScopeTState(TState state){ return null;}} 我这里面的Debug.WriteLine是为了方便调试. 正常情况下当然是写入日志文件,可以用Log4Net 然后,我们创建一个空的日志类(用来过滤不需要记录的日志)如下: private class NullLogger : ILogger{ public bool IsEnabled(LogLevel logLevel){ return false;} public void LogTState(LogLevel logLevel, EventId eventId, TState state, Exception exception, FuncTState, Exception, string formatter){ } public IDisposable BeginScopeTState(TState state){ return null;}} 然后,我们创建一个日志提供类(注入用,EF Core1.0版本注意注释),如下: public class MyFilteredLoggerProvider : ILoggerProvider{ public ILogger CreateLogger(string categoryName){ // NOTE: 这里要注意,这是 EF Core 1.1的使用方式,如果你用的 EF Core 1.0, 就需把IRelationalCommandBuilderFactory替换成下面的类       // Microsoft.EntityFrameworkCore.Storage.Internal.RelationalCommandBuilderFactoryif (categoryName typeof(IRelationalCommandBuilderFactory).FullName){ return new EFLogger(categoryName);} return new NullLogger();} public void Dispose(){ } } 然后我们到Startup.cs的Configure()方法中注入我们的日志提供类 代码如下: public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory){loggerFactory.AddProvider(new MyFilteredLoggerProvider());....省略 } 运行程序,得到如下调试信息: 至此,我们就完成了日志的记录工作. 那么问题来了,在Asp.NET core中,我们可以这样注入进行日志记录. 如果在别的项目(比如控制台)中,怎么办? 下面就来解决这个问题. 在非Asp.NET core的程序中,我们需要把日志提供器从上下文里注入如下: protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder){ base.OnConfiguring(optionsBuilder);LoggerFactory loggerFactory new LoggerFactory();loggerFactory.AddProvider(new MyFilteredLoggerProvider()); //注入optionsBuilder.UseLoggerFactory(loggerFactory);} 写在最后 写在最后,其实在EF Core的路线图中,我们可以看到,在2.0的版本将会提供一个更简单的日志记录方式 这段话是在(Features originally considered but for which we have made no progress and are essentially postponed)之后的: ..上面翻译过来的大概意思就是:我们原来考虑会加入的功能,但是现在并没有进展,基本要推迟的特点.(..总结三个字,然并卵) Simple Logging API (#1199) - We want a simple way to log the SQL being executed (like Database.Log from EF6.x). We also want a simple way to view everything being logged.嗯..翻译过来的意思就是..我们想提供一个更简单的日志记录,比如像EF6.x中的 Database.Log 这样...() 还有一个比较有趣的东西如下: 在High priority features(高度优先的功能)中还有一段话: Simple command interception provides an easy way to read/write commands before/after they are sent to the database.简单的命令拦截,将提供在发送到数据库之前/之后读取/写入命令的简单方法 我觉得这个有点类似于EF6.x的IDbCommandInterceptor. 相关文章 一步步学习EF Core(1.DBFirst) 原文地址http://www.cnblogs.com/GuZhenYin/p/6862505.html .NET社区新闻深度好文微信中搜索dotNET跨平台或扫描二维码关注
http://www.zqtcl.cn/news/166497/

相关文章:

  • 站长 网站ip客户都不愿意做网站
  • 网站开发和软件开发哪个难网站备案账号
  • 2昌平区网站建设安徽盛绿建设网站
  • 商务网站建设目的天津建设网站需要的费用
  • flash 网站头部wordpress支持大文件上传
  • 网站开发方式的选择凡客设计
  • 常德建设网站如何查询某个网站的设计公司
  • wordpress 仿站教程学校ui设计培训
  • 南昌模板建站定制网站合肥瑶海区网站建设价格
  • 奥尔马手表官方网站导出wordpress文章
  • 网站栏目内容和功能手机网站建设 如何获得更好的排名
  • 网站运营推广难做常德网警
  • 北滘网站建设公司在百度上做网站怎么做
  • 合肥网站建设 毅耘园林设计网站大全
  • 免费备案网站空间爱营销app
  • 郑州网站建设公网站建设需要步骤
  • 源创派网站建设做软件赚钱的网站有哪些
  • 中英文网站建设公司推广引流
  • 网站改域名百度热词指数
  • 网站开发工程师工作内容网站源码是用什么做的
  • 做网站优化费用免费的视频网站如何赚钱
  • 如何制作一个好网站中国建设银行网站暑假工报名
  • 阿里巴巴做网站找谁网站建设需要ui吗
  • 如何评价伊利集团网站建设长沙专业竞价优化首选
  • 网站建设费用标准做网站怎么盈利
  • 仕德伟做的网站图片怎么修initial wordpress
  • 网站制作公司多少费用正规的机械外包加工订单网
  • 网站的维护和推广2345网址大全设主页访问
  • 天津商城网站建设公司如何申请注册企业邮箱
  • 做家旅游的视频网站好给我一个可以在线观看的免费