LINQ能不能用系列(二)LINQ to SQL 效率比对

前言

很多人听说过LINQ TO SQL与ADO.NET传统方式用于不同的环境,LINQ TO SQL与ADO.NET传统方式也没有可比性,就像公交车与私家车一样,虽然是车但用途完全不同,但很少有人去探究,究竟为什么他们不同,他们不同的原因是什么,这我觉得是一个好的程序和一个普通程序最主要的区别之一。下面一起来看LINQ TO SQL效率到底如果吧。

内容

测试环境:net framework 4.0 + Sql Server 2008

测试用途:100w条数据 like 查询,原因添加、修改、删除消耗资源与时间相对较少,不易测试,查询里面最消耗时间的无非就是 like 与 in查询,我们就采用like 相对比较耗时与耗时间的典型来测。

测试数据:100w条测试数据(其中有一条数据有别于其他数据,在数据的最中央)

测试数据图:

 

测试脚本:

View Code

测试项目图:

核心代码:

GameInfoBLL.cs

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;

namespace LINQProject
{
    /// <summary>
    /// 游戏信息业务处理类(LINQ TO SQL 效率测试用)
    /// 王磊(Stone)
    /// 2012.05.18
    /// </summary>
    public class GameInfoBLL
    {

        #region 根据游戏名称模糊查询
        /// <summary>
        /// 根据游戏名称模糊查询
        /// </summary>
        /// <param name="name">游戏名称呢个</param>
        /// <returns>List<GameInfoModel></returns>
        public static List<GameInfoModel> GetGameInfoByGname(string name)
        {
            List<GameInfoModel> list = new List<GameInfoModel>(1000000);
            string sql = "select * from gameinfo where gamename like @gamename";
            SqlDataReader dr = null;
            try
            {
                using (dr = DBHelper.GetSqlDataReaderBySql(sql, new SqlParameter[]{
                new SqlParameter("@gamename","%"+name+"%") }))
                {
                    GameInfoModel game = new GameInfoModel();
                    while (dr.Read())
                    {
                        game.gid = (int)dr["gid"];
                        game.gamename = (string)dr["gamename"];
                        game.createtime = (DateTime)dr["createtime"];
                        game.content = (string)dr["content"];
                        game.gametype = (int)dr["gametype"];
                        list.Add(game);
                    }
                }
            }
            catch (Exception ex)
            {
                if (null != dr && !dr.IsClosed)
                {
                    dr.Close();
                }
                throw ex;
            }
            return list;
        }
        #endregion

    }
}
复制代码

DBHelper.cs

View Code

测试类代码:

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Diagnostics;

namespace LINQProject
{
    class Program
    {
        static void Main(string[] args)
        {

            for (int i = 1; i < 10; i++)
            {
                Test(i);
            }
            Console.Read();
        }

        /// <summary>
        /// 效率方法测试
        /// </summary>
        private static void Test(int testNumber)
        {
            Stopwatch linqWatch = new Stopwatch();
            linqWatch.Start();
            // LINQ 查询
            DataClasses1DataContext db = new DataClasses1DataContext();
            var glist = from g in db.gameinfo
                        where g.gamename.Contains("Dota")
                        select g;

            // foreach 遍历
            foreach (var item in glist)
            {
                Console.Write("LINQ:" + item.gamename + " ");
            }
            linqWatch.Stop();

            Stopwatch adoWatch = new Stopwatch();
            adoWatch.Start();
            // ADO.NET 查询
            List<GameInfoModel> list = GameInfoBLL.GetGameInfoByGname("Dota");
            // foreach 遍历
            foreach (GameInfoModel item in list)
            {
                Console.WriteLine("ADO.NET:" + item.gamename);
            }
            adoWatch.Stop();

            Console.WriteLine("================================结果" + testNumber + "=========================================");
            Console.WriteLine(String.Format("LINQ 用时:{0} \r\nADO.NET 用时:{1}",
               linqWatch.ElapsedMilliseconds, adoWatch.ElapsedMilliseconds));
        }
    }
}
复制代码

测试项目下载:点击

结果

如图:

LINQ TO SQL第一次的时候比较消耗资源,原因LINQ第一次初始化比较耗时,之后LINQ查询与ADO.NET几乎一样,在100w条数据下随然数据大同小异,但已经足够说明问题,LINQ TO SQL 还是可以用的,起码中小型项目可以放心使用。

大家如有好的建议或者意见欢迎拍板。

 




本文转自王磊的博客博客园博客,原文链接:http://www.cnblogs.com/vipstone/archive/2012/05/18/2508209.html,如需转载请自行联系原作者

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值