Insert测试,只测试1000条的情况,多了在实际的项目中应该就要另行处理了。

using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data.Entity;
using System.Diagnostics;
using System.Linq;
using EE.Service.DbAccess;
using EE.Service.DbEntity;
using EntityFramework.Extensions;
using EntityFramework.Future;
using MySql.Data.MySqlClient; namespace EE.Services.ConsoleTest.DbAccessTests
{
public class EFPerformanceTest
{
public static void Run()
{
//InsertTest(); UpdateTests();
} #region UpdateTest() static void UpdateTests()
{
var list = new List<SmsLog>();
for (int i = ; i < ; i++)
{
list.Add(new SmsLog() { Id = i, AppId = $"{i}_", CreateTime = DateTime.Now });
}
var sw = new Stopwatch();
Watcher(sw, EFInit, list.GetRange(, )); Watcher(sw, MySqlSelect, list); Watcher(sw, EFSelect,list); Watcher(sw, MySqlUpdate, list); Watcher(sw, EFBulkUpdate, AddRangeId(list)); Watcher(sw, EFUpdateWithNoState, AddRangeId(list)); Watcher(sw, EFUpdate, AddRangeId(list)); } static IEnumerable<SmsLog> AddRangeId(IEnumerable<SmsLog> logs)
{
foreach (var log in logs)
{
log.Id += ;
}
return logs;
} static int EFSelect(IEnumerable<SmsLog> items)
{
using (var db = new ServiceLogDbContent())
{
var val = ;
foreach (var item in items)
{
var rst = (from tb in db.SmsLogs where tb.Id == select tb).FirstOrDefault();
if (rst != null) val++;
}
return val;
}
} static int EFUpdate(IEnumerable<SmsLog> items)
{
using (var db = new ServiceLogDbContent())
{
foreach (var item in items)
{
//db.SmsLogs.Attach(item);
var o = db.SmsLogs.Where(x => x.Id == item.Id).FirstOrDefault();
if (o == null) continue;
o.AppId = item.AppId+"U";
o.CreateTime = item.CreateTime;
}
var val = db.SaveChanges();
return val;
}
} static int EFUpdateWithNoState(IEnumerable<SmsLog> items)
{
using (var db = new ServiceLogDbContent())
{
db.Configuration.AutoDetectChangesEnabled = false;
db.Configuration.ValidateOnSaveEnabled = false;
db.Configuration.LazyLoadingEnabled = false;
db.Configuration.ProxyCreationEnabled = false;
var val = ;
foreach (var item in items)
{
//传统更新方式 .. 更新不了(没有状态,无法完成更新)
var o = db.SmsLogs.Where(x => x.Id == item.Id).FirstOrDefault();
if (o == null) continue;
o.AppId = item.AppId+"SU";
o.CreateTime = item.CreateTime;
}
val = db.SaveChanges();
return val;
}
} static int EFBulkUpdate(IEnumerable<SmsLog> items)
{
using (var db = new ServiceLogDbContent())
{
foreach (var item in items)
{
var o = db.SmsLogs.Where(x => x.Id == item.Id).FirstOrDefault();
if (o == null) continue;
o.AppId = item.AppId+"BU";
o.CreateTime = item.CreateTime;
}
db.BulkSaveChanges();
return ;
}
} static int MySqlUpdate(IEnumerable<SmsLog> items)
{
var val = ;
var connStr = ConfigurationManager.ConnectionStrings["EEServiceLogDb"].ConnectionString;
using (var conn = new MySqlConnection(connStr))
{
conn.Open();
foreach (var item in items)
{
val += MySqlHelper.ExecuteNonQuery(conn, "Update SmsLogs set AppId=@appId,CreateTime=@createTime where Id = @id;", new MySqlParameter("@appId", item.AppId+"S"), new MySqlParameter("@createTime", item.CreateTime), new MySqlParameter("@id", item.Id));
}
conn.Close();
}
return val;
}
static int MySqlSelect(IEnumerable<SmsLog> items)
{
var val = ;
var connStr = ConfigurationManager.ConnectionStrings["EEServiceLogDb"].ConnectionString;
using (var conn = new MySqlConnection(connStr))
{
conn.Open();
foreach (var item in items)
{
var dr = MySqlHelper.ExecuteReader(conn, "select * from SmsLogs where Id = @id;", new[] { new MySqlParameter("@id", item.Id) });
while (dr.Read())
{
val += ;
}
dr.Close();
}
conn.Close();
}
return val;
} #endregion #region InsertTest() static void InsertTest()
{
var list = new List<SmsLog>();
for (int i = ; i < ; i++)
{
list.Add(new SmsLog() { AppId = $"{i}", CreateTime = DateTime.Now });
}
var sw = new Stopwatch(); Watcher(sw, EFInit, list.GetRange(, ));
Watcher(sw, EFBulkInsert, list);
Watcher(sw, EFInsertWithNoState, list);
Watcher(sw, EFInsert, list);
Watcher(sw, MySqlInsert, list);
//Watcher(sw, EFInsert, list); } static int EFInsert(IEnumerable<SmsLog> items)
{
using (var db = new ServiceLogDbContent())
{
foreach (var item in items)
db.SmsLogs.Add(item); var val = db.SaveChanges();
return val;
}
} static int EFInsertWithNoState(IEnumerable<SmsLog> items)
{
using (var db = new ServiceLogDbContent())
{
db.Configuration.AutoDetectChangesEnabled = false;
db.Configuration.ValidateOnSaveEnabled = false;
db.Configuration.LazyLoadingEnabled = false;
db.Configuration.ProxyCreationEnabled = false; foreach (var item in items)
db.SmsLogs.Add(item); var val = db.SaveChanges();
return val;
}
} static int EFBulkInsert(IEnumerable<SmsLog> items)
{
using (var db = new ServiceLogDbContent())
{
//db.Configuration.AutoDetectChangesEnabled = false;
//db.Configuration.ValidateOnSaveEnabled = false;
foreach (var item in items)
db.SmsLogs.Add(item); db.BulkSaveChanges();
return ;
}
} static int MySqlInsert(IEnumerable<SmsLog> items)
{
var val = ;
var connStr = ConfigurationManager.ConnectionStrings["EEServiceLogDb"].ConnectionString;
using (var conn = new MySqlConnection(connStr))
{
conn.Open();
foreach (var item in items)
{
val += MySqlHelper.ExecuteNonQuery(conn, "Insert into SmsLogs(AppId,CreateTime)values(@appId,@createTime)", new MySqlParameter("@appId", item.AppId), new MySqlParameter("@createTime", item.CreateTime));
}
conn.Close();
}
return val;
} #endregion /// <summary>
/// 初始化一下,尽量减少EF初始化时间的影响
/// </summary>
/// <param name="items"></param>
/// <returns></returns>
static int EFInit(IEnumerable<SmsLog> items)
{
using (var db = new ServiceLogDbContent())
{
foreach (var item in items)
{
var o = db.SmsLogs.FirstOrDefault(x => x.Id == item.Id);
if (o != null)
{
o.AppId = "Init";
}
}
var val = db.SaveChanges();
return val;
}
} static void Watcher<T>(Stopwatch stopwatch, Func<IEnumerable<T>, int> func, IEnumerable<T> list)
{
if (stopwatch == null) stopwatch = new Stopwatch();
stopwatch.Reset();
Console.WriteLine($"[{DateTime.Now:HH:mm:ss ffffff}] {func.Method.Name} BEGIN =====================================================");
stopwatch.Start();
var val = func(list);
stopwatch.Stop();
Console.WriteLine($"[{DateTime.Now:HH:mm:ss ffffff}] {func.Method.Name}[{stopwatch.Elapsed} IN<{list.Count()}> -> RS<{val}>]");
//Console.WriteLine($"[{DateTime.Now:HH:mm:ss ffffff}] {func.Method.Name} end");
} }
}

本机开发机,DB在内网服务器上。测试结果:

可以看到,EF的初始执行还是蛮耗时间的。扩展的BuilInsert要比循环的MySqlInsert语句效率还好一些。关掉状态跟踪与默认情况,差别不大(不知是不是我写的有问题)。

这么一看,是因为查询慢吗?

更新的方式就是选Where出对象,再修改对象的值,再SaveChagnes。 难道是我写的方式不对?为什么查询这么慢?

-----------------------------------------------------------------------------------------------------------------------------------

原来不是我的写的问题,而是配置问题,连接串中没有池化与有池化的结果相差近10倍。这算什么???

Pooling=false|true;

连接串中的这个就是影响性能差别巨大的“元凶”

下面的是EF的Save,即AddOrUpdate ,通过1000条的测试发现:耗时都在4~5秒左右。比起先Select再Update还是要耗时一些。所以在性能有要求的地方,要稍微慎重一些。是不是先读取后赋值一下再Update。还是直接AddOrUpdate

 

测试EntityFramework,Z.EntityFramework.Extensions,原生语句在不同的查询中的表现。原来池化与非池化设定是有巨大的影响的。的更多相关文章

  1. 第九节: EF的性能篇(二) 之 Z.EntityFramework.Extensions程序集解决EF的性能问题

    一. 综述 该模块主要介绍:EF的性能优化插件Z.EntityFramework.Extensions,该插件收费. (一). 简介 1. 相关网站:http://www.zzzprojects.co ...

  2. 【EF】解决EF批量操作,Z.EntityFramework.Extensions 过期方案

    方案一: 使用EntityFramework.Extended优点: 启下载量是Z.EntityFramework.Extensions的10倍+ 不会过期缺点:不能批量Insert 方案二:解决批量 ...

  3. 自己动手破解Z.EntityFramework.Extensions 4.0.11.0的方法

    因为项目中使用到Z.EntityFramework.Extensions 和 Z.EntityFramework.Plus(免费开源)两个类库,但是Z.EntityFramework.Extensio ...

  4. 破解EFCore扩展Dll --- Z.EntityFramework.Extensions.EFCore

    安装 Z.EntityFramework.Extensions.EFCore Install-Package Z.EntityFramework.Extensions.EFCore -Version ...

  5. 第二十三节: EF性能篇(三)之基于开源组件 Z.EntityFrameWork.Plus.EF6解决EF性能问题

    一. 开篇说明 EF的性能问题一直以来经常被人所吐槽,究其原因在于“复杂的操作在生成SQL阶段耗时长,且执行效率不高”,但并不是没有办法解决,从EF本身举几个简单的优化例子: ①:如果仅是查询数据,并 ...

  6. Cookies 初识 Dotnetspider EF 6.x、EF Core实现dynamic动态查询和EF Core注入多个上下文实例池你知道有什么问题? EntityFramework Core 运行dotnet ef命令迁移背后本质是什么?(EF Core迁移原理)

    Cookies   1.创建HttpCookies Cookie=new HttpCookies("CookieName");2.添加内容Cookie.Values.Add(&qu ...

  7. MongoDB学习笔记~使用原生语句实现三层集合关系的更新

    回到目录 MongoDB的文档型数据结构使得它在存储数据上很像JSON,在可读性方面很强,然而这种复杂的结构在update时相对麻烦一些,而对于官方给出的文档说的也不够细致,有些东西也是模棱两可的态度 ...

  8. Mysql存储之原生语句操作(pymysql)

    Mysql存储之原生语句操作(pymysql) 关系型数据库是基于关系模型的数据库,而关系模型是通过二维表时实现的,于是构成了行列的表结构. 表可以看作是某个实体的集合,而实体之间存在联系,这个就需要 ...

  9. sql语句(已在Oracle中测试,之后有添加内容放在评论中)

    1增 1.1[创建一张表] create table 表名(列名 类型); 例: ),性别 ),出生日期 date); ),sex ),出生日期 date); 1.2[插入单行]insert [int ...

随机推荐

  1. Notes:SVG(3)---滤镜和渐变

    SVG滤镜使用filter标签来定义,该标签必须嵌套在defs元素里面,并且必须指定一个ID,以供引用. 在 SVG 中,可用的滤镜有: feBlend feColorMatrix feCompone ...

  2. 面向对象的JS(一)

    JavaScript是弱类型,可变性强 /*JavaScript和其他的语言类似,也是面向对象,自然也就是存在类和对象(对象是类的实例化)*/ //1.JS对象 var empty = {}; //没 ...

  3. Base-64 字符数组或字符串的长度无效等问题解决方案

    项目特殊需要,调用ActiveX三维控件进行控件某一特殊部位的截图操作,这个截图保存由ActiveX控件控制保存到本地是没问题的,现在需要将这个截图上传到服务器,多人共享,就牵扯到需要读取本地文件…… ...

  4. Linux下的解压命令小结

    Linux下常见的压缩包格式有5种:zip tar.gz tar.bz2 tar.xz tar.Z 其中tar是种打包格式,gz和bz2等后缀才是指代压缩方式:gzip和bzip2 filename. ...

  5. 前端开发:Javascript中的数组,常用方法解析

    前端开发:Javascript中的数组,常用方法解析 前言 Array是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array ...

  6. 在DevExpress程序中使用Winform分页控件直接录入数据并保存

    一般情况下,我们都倾向于使用一个组织比较好的独立界面来录入或者展示相关的数据,这样处理比较规范,也方便显示比较复杂的数据.不过在一些情况下,我们也可能需要直接在GridView表格上直接录入或者修改数 ...

  7. Be a new gentlemen

    学好技术的同时,更要注重自身素养的提升! 一  .有则改之,无责加冕 1.女士优先 2. 不随地吐痰, 不乱扔垃圾, 不在人群中抽烟 3. 不大声喧哗 4. 不插队,碰到别人要说抱歉 5. 不在公共交 ...

  8. chunkupload文件上传断点续传组件(java)

    chunkupload简介 chunkupload是一款基于java语言的断点续传组件,针对文件上传,非文件下载,集成方便,使用简单. 从整体上讲,chunkupload会对文件进行切片处理,每个切片 ...

  9. HTML5 数据集属性dataset

    有时候在HTML元素上绑定一些额外信息,特别是JS选取操作这些元素时特别有帮助.通常我们会使用getAttribute()和setAttribute()来读和写非标题属性的值.但为此付出的代价是文档将 ...

  10. Maven远程仓库的认证

    大部分远程仓库无须认证就可以访问,但有时处于安全方面的考虑,我们需要提供认证信息才能访问一些远程仓库.为了防止非法的仓库访问,管理员为每个仓库提供了一组用户名及密码. 这时,为了能让Maven访问仓库 ...