using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Data.Entity;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Diagnostics;
using TH.Com.General;
using TH.Common; public partial class EFUpdate : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{ }
protected void Button1_Click(object sender, EventArgs e)
{
var sp = new Stopwatch();
sp.Start(); var isSqlBulkCopy = true;
var list = new List<Article>();
using (var da = new THCommon())
{
Random rand = new Random(); for (var i = ; i < ; i++)
{
var art = new Article();
art.ID = Guid.NewGuid();
art.Area = Convert.ToDecimal(rand.Next() / 100.0);
art.CreateBy = "sdm";
art.CreateTime = DateTime.Now.AddMinutes(i);
art.Height = rand.Next();
art.Name = "Name" + i;
art.Note = "This is Note" + i;
art.Number = i;
art.Price = Convert.ToDecimal(rand.Next() / 100.0);
art.Weight = Convert.ToDecimal(rand.Next() / 100.0); list.Add(art); }
sp.Stop();
Debug.Print("Articles.Add = " + sp.ElapsedMilliseconds);
sp.Restart(); if (isSqlBulkCopy)
{
SaveList(da, list);
}
else
{
da.Articles.AddRange(list);
da.SaveChanges();
} sp.Stop();
Debug.Print("SaveChanges = " + sp.ElapsedMilliseconds);
sp.Restart();
}
} private void SaveList(DbContext db, List<Article> list)
{
//保存上传记录
var tableToInsert = Tools.ListToDataTable(list);
string cnstr = db.Database.Connection.ConnectionString;
using (var sqlBC = new SqlBulkCopy(cnstr))
{
sqlBC.DestinationTableName = "Art.Article";
sqlBC.BatchSize = ;
sqlBC.BulkCopyTimeout = ;
sqlBC.WriteToServer(tableToInsert);
}
} //更新测试
protected void Button2_Click(object sender, EventArgs e)
{
Debug.Print("测试数据更新方法速度比较");
Debug.Print("1.ef直接更新"); //EFUpdate1(10000);
//EFUpdate2(10000);
SqlDataAdapterUpdate();
} private void EFUpdate1(int count)
{
var sp = new Stopwatch();
sp.Start();
using (var da = new THCommon())
{
var list = da.Articles.Take().ToList(); sp.Stop();
Debug.Print("ToList = " + sp.ElapsedMilliseconds);
sp.Restart(); list.ForEach(t => t.Area = t.Height * t.Price);
sp.Stop();
Debug.Print("ForEach = " + sp.ElapsedMilliseconds);
sp.Restart(); da.SaveChanges(); sp.Stop();
Debug.Print("SaveChanges = " + sp.ElapsedMilliseconds);
sp.Restart();
}
} private void EFUpdate2(int count)
{
var sp = new Stopwatch();
sp.Start();
using (var da = new THCommon())
{
var list = da.Articles.Take().ToList(); var sql = "update art.article set Area = Height * Price where createtime<'2017-01-07 10:13:54.870' "; da.Database.ExecuteSqlCommand(sql); sp.Stop();
Debug.Print("ExecuteSqlCommand = " + sp.ElapsedMilliseconds);
sp.Restart();
}
} private void SqlDataAdapterUpdate()
{
var sp = new Stopwatch();
sp.Start();
using (var da = new THCommon())
{
var conn = (SqlConnection)da.Database.Connection; //设置select查询命令,SqlCommandBuilder要求至少有select命令
var selectCMD = new SqlCommand("select * from art.article where createtime<'2017-01-07 10:13:54.870'", conn);
var dt = new DataTable();
var sda = new SqlDataAdapter(selectCMD); //上面的语句中使用select 0,不是为了查询出数据,而是要查询出表结构以向DataTable中填充表结构
sda.Fill(dt); foreach (DataRow row in dt.Rows)
{
row["Area"] = Convert.ToDecimal(row["Height"]) * Convert.ToDecimal(row["Price"]);
}
//SqlCommandBuilder scb = new SqlCommandBuilder(sda); var dtc = dt.GetChanges();
SqlCommandBuilder scb = new SqlCommandBuilder(sda); sp.Stop();
Debug.Print("SqlCommandBuilder = " + sp.ElapsedMilliseconds);
sp.Restart(); if (dtc != null)
{
//执行更新
sda.Update(dtc);
} ////使DataTable保存更新
//dt.AcceptChanges(); sp.Stop();
Debug.Print("sda.Update = " + sp.ElapsedMilliseconds);
sp.Restart();
} } protected void Button3_Click(object sender, EventArgs e)
{
var sp = new Stopwatch();
sp.Start(); var list = new List<Article>(); var isDeleteSql = true; using (var da = new THCommon())
{
if (isDeleteSql)
{
var start = Convert.ToDateTime("2017-01-16");
var end = Convert.ToDateTime("2017-01-18"); var toDeleteListIDS =
da.Articles.Where(
t =>
t.CreateTime > start &&
t.CreateTime < end).Select(t => t.ID).ToList();
var ids = string.Join("','", toDeleteListIDS.ToArray());
var sql = string.Format("delete art.article where id in ('{0}') ", ids); da.Database.ExecuteSqlCommand(sql); sp.Stop();
Debug.Print("ExecuteSqlCommand delete = " + sp.ElapsedMilliseconds);
sp.Restart();
}
else
{
var dels = da.Articles.Take(); da.Articles.RemoveRange(dels);
da.SaveChanges();
sp.Stop();
Debug.Print("RemoveRange = " + sp.ElapsedMilliseconds);
sp.Restart();
} }
} /// <summary>
/// 先删除,再插入,在事务中执行
/// </summary>
private void DeleteAndInsert()
{
var rand = new Random();
using (var da = new THCommon())
{
using (System.Data.Entity.DbContextTransaction dbTran = da.Database.BeginTransaction())
{
try
{
var start = Convert.ToDateTime("2017-01-20");
var end = Convert.ToDateTime("2017-01-21"); var list = da.Articles.Where(t => t.CreateTime > start && t.CreateTime < end).ToList();
var ids = string.Join("','", list.Select(t => t.ID).ToArray()); //删除
var sql = string.Format("delete art.article where id in ('{0}') ", ids);
da.Database.ExecuteSqlCommand(sql); list.ForEach(delegate(Article art)
{
art.Height = ;
art.Number = ;
art.Weight = ;
art.Area = rand.Next();
}); SaveList(da, list); //commit transaction
dbTran.Commit();
}
catch (Exception ex)
{
//Rollback transaction if exception occurs
dbTran.Rollback();
} } }
}
protected void Button4_Click(object sender, EventArgs e)
{
DeleteAndInsert();
}
   protected void Button5_Click(object sender, EventArgs e)
{
//1.删除临时表
//2.选择记录,并修改,并批插入表临时表
//3.update from var sp = new Stopwatch();
sp.Start(); using (var da = new THCommon())
{
var list = da.Articles.Take(100000).ToList(); sp.Stop();
Debug.Print("ToList = " + sp.ElapsedMilliseconds);
sp.Restart(); list.ForEach(delegate(Article art)
{
art.Area = 1;
art.Height = 2;
art.Number = 3;
art.Price = 4;
art.Weight = 5;
}); sp.Stop();
Debug.Print("ForEach = " + sp.ElapsedMilliseconds);
sp.Restart(); var sql = "truncate table art.articletmp";
da.Database.ExecuteSqlCommand(sql); sp.Stop();
Debug.Print("ExecuteSqlCommand truncate = " + sp.ElapsedMilliseconds);
sp.Restart(); //保存上传记录
var tableToInsert = Tools.ListToDataTable(list);
string cnstr = da.Database.Connection.ConnectionString;
using (var sqlBC = new SqlBulkCopy(cnstr))
{
sqlBC.DestinationTableName = "Art.ArticleTmp";
sqlBC.BatchSize = 10000;
sqlBC.BulkCopyTimeout = 300;
sqlBC.WriteToServer(tableToInsert);
} sp.Stop();
Debug.Print(" SqlBulkCopy = " + sp.ElapsedMilliseconds);
sp.Restart(); sql = "update art.article set area = t0.area,height=t0.height,number = t0.number,price = t0.price,weight = t0.weight from art.articletmp t0 where art.article.id = t0.id";
da.Database.ExecuteSqlCommand(sql);
sp.Stop();
Debug.Print("ExecuteSqlCommand update = " + sp.ElapsedMilliseconds);
sp.Restart(); }
}

  

}

EFUpdate的更多相关文章

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

    Insert测试,只测试1000条的情况,多了在实际的项目中应该就要另行处理了. using System; using System.Collections.Generic; using Syste ...

  2. Unity框架入门

    介绍Unity框架之前,先要说几个概念DIP依赖倒置原则.IOC控制反转.DI依赖注入 DIP是设计原则之一,定义:上层不应该依赖于底层,两者都依赖于抽象: 抽象不依赖于细节,细节应该依赖于抽象. 像 ...

  3. ADO,net 实体数据模型增、删、改,浅谈

    第一步:建立ADO.net数据模型,一步步操作就行 第二步:画个简单的测试界面 第三步铺代码 using DevComponents.DotNetBar.SuperGrid; using DevCom ...

随机推荐

  1. LISA介绍及其使用方法

    LISA是ARM公司开发的一款开源工具.在内核开发过程中,苦于无法针对修改内容进行一些量化或者可视化结果的测量,而无感.LISA对于模型调优,回归测试都有较强的支持. 什么是LISA? LISA是Li ...

  2. canvas-图片翻转

    图片90度翻转 在canvas中插入图片需先加载图片(利用Image对象);加载完成后再执行操作drawImage(obj,x,y,w,h) 插入图片的坐标宽高等值 <!DOCTYPE html ...

  3. 解决win7系统重启后ip丢失问题,即每次电脑重启都要重新设置ip地址,重启后ip地址没了

    自己制作的Ghost盘上网有点问题,每次重启后电脑的ip地址被还原,要重新设置 百度后终于找解决办法,在此记录. 第一步:点击左下角的WIN图标,输入CMD然后回车,打开DOS模式窗口. 第二步:在D ...

  4. bzoj1251

    1251: 序列终结者 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 3776  Solved: 1581[Submit][Status][Discu ...

  5. NSRunLoop的进一步理解

    iPhone应用开发中关于NSRunLoop的概述是本文要介绍的内容,NSRunLoop是一种更加高明的消息处理模式,他就高明在对消息处理过程进行了更好的抽象和封装,这样才能是的你不用处理一些很琐碎很 ...

  6. 网络流模板 NetworkFlow

    身边的小伙伴们都在愉快地刷网络流,我也来写一发模板好了. Network Flow - Maximum Flow Time Limit : 1 sec, Memory Limit : 65536 KB ...

  7. maven引入多个spring jar包中存在同名文件的问题

    项目打包后执行报错:Configuration problem: Unable to locate Spring NamespaceHandler for XML schema namespaceht ...

  8. 《JAVA与模式》之观察者模式

    转自:http://www.cnblogs.com/java-my-life/archive/2012/05/16/2502279.html 在阎宏博士的<JAVA与模式>一书中开头是这样 ...

  9. wireshark抓包工具简介以及tcp三次握手的一些含义

    wireshark是非常流行的网络封包分析软件,功能十分强大.可以截取各种网络封包,显示网络封包的详细信息.使用wireshark的人必须了解网络协议,否则就看不懂wireshark了.为了安全考虑, ...

  10. Oracle基本查询语言

    --1.简单的数据查询语句--查询所有的员工的信息select * from emp;--查询员工的姓名和工作职位select ename,job from emp;--姓名和工作以中文的形式显示出来 ...