驳Fish的ORM性能问题.如有疑问大家公测.


一下是测试代码.代码采用fish给的.数据库也是他给的./Files/humble/TestFish.7z

 //

/*
 * 由SharpDevelop创建。
 * 用户: Administrator
 * 日期: 2012/8/20
 * 时间: 10:50
 * 
 * 要改变这种模板请点击 工具|选项|代码编写|编辑标准头文件
 
*/
using System;
using System.Configuration;
using System.Data.SqlClient;
using System.Linq;

using ClownFish;
using Dapper;
using Moon.Orm;

namespace TestFish
{
     public  class OrderInfo
    {
         public  int OrderID {  getset; }
         public DateTime OrderDate {  getset; }
         public  decimal SumMoney {  getset; }
         public  string Comment {  getset; }
         public  bool Finished {  getset; }
         public  int ProductID {  getset; }
         public  decimal UnitPrice {  getset; }
         public  int Quantity {  getset; }
         public  string ProductName {  getset; }
         public  int CategoryID {  getset; }
         public  string Unit {  getset; }
         public  string Remark {  getset; }
        
         //  注意:客户信息有可能会是DBNull
         public  int? CustomerID {  getset; }
         public  string CustomerName {  getset; }
         public  string ContactName {  getset; }
         public  string Address {  getset; }
         public  string PostalCode {  getset; }
         public  string Tel {  getset; }
    }
     class Program
    {
        
         static  void AppInit()
        {
            ConnectionStringSettings setting = ConfigurationManager.ConnectionStrings[ " MyNorthwind "];
            ConnectionString = setting.ConnectionString;

             //  配置 ClownFish
            ClownFish.DbContext.RegisterDbConnectionInfo( " default ", setting.ProviderName,  " @ ", setting.ConnectionString);

            Type[] types = ClownFish.BuildManager.FindModelTypesFromCurrentApplication(x => x.Namespace ==  " PerformanceTestApp.Model ");
            ClownFish.BuildManager.CompileModelTypesSync(types,  true);

             //  配置 FishWebLib
            FishWebLib.FishDbContext.Init(setting.ProviderName,  " @ ", setting.ConnectionString);
        }
         protected  static  string ConnectionString;
         private  static  ClownFish.DbContext db;
     
         public  static  readonly  string QueryText2 =  @"
select top (1000) d.OrderID, d.OrderDate, d.SumMoney, d.Comment, d.Finished,
dt.ProductID, dt.UnitPrice, dt.Quantity,
p.ProductName, p.CategoryID, p.Unit, p.Remark,
c.CustomerID, c.CustomerName, c.ContactName, c.Address, c.PostalCode, c.Tel
from Orders d
inner join [Order Details] dt on d.OrderId = dt.OrderId
inner join Products p on dt.ProductId = p.ProductId
left join Customers c on d.CustomerId = c.CustomerId
";
        
        
        
        
         public  static SqlConnection GetSqlConnection()
        {
             var connection =  new SqlConnection(ConfigurationManager.AppSettings[ " linkString "]);
            connection.Open();
             return connection;
        }
        
         public  static  void Main( string[] args)
        {
             // -------------这些可以不理会
             var t1=DateTime.Now.Ticks;
            AppInit();
            db =  new ClownFish.DbContext( false);
             var parameter =  new { TopN = 1000 };
             var list= ClownFish.DbHelper.FillList<OrderInfo>(
                QueryText2,  null, db, ClownFish.CommandKind.SqlTextWithParams);
             var t2=DateTime.Now.Ticks;
            Console.WriteLine(t2-t1);
             var t3=DateTime.Now.Ticks;
             var list2=DBFactory.GetEntities<OrderInfo>(QueryText2);
             var t4=DateTime.Now.Ticks;
            Console.WriteLine(t4-t3);
            SqlConnection connection = Program.GetSqlConnection();
             // --------------------------------------------------------------------------------------
            
            
             var dd = connection.Query<OrderInfo>(QueryText2,  null).ToList<OrderInfo>();
            
             // --------------------前面的可以不算,咱们正式开始
             var tFish1=DateTime.Now.Ticks;
             for ( int i =  0; i <  1000; i++) {
                 var listFish= ClownFish.DbHelper.FillList<OrderInfo>(
                    QueryText2,  null, db, ClownFish.CommandKind.SqlTextWithParams);
            }
             var tFish2=DateTime.Now.Ticks;
            Console.WriteLine( " 小鱼的时间: "+(tFish2-tFish1));
             // ------------------
             var tMoon1=DateTime.Now.Ticks;
             for ( int i =  0; i <  1000; i++) {
                 var listMoon=DBFactory.GetEntities<OrderInfo>(QueryText2);
            }
             var tMoon2=DateTime.Now.Ticks;
            Console.WriteLine( " MOON的时间: "+(tMoon2-tMoon1));
            
             var tRapper1=DateTime.Now.Ticks;
             for ( int i =  0; i <  1000; i++) {
                 var listRapper = connection.Query<OrderInfo>(QueryText2,  null).ToList<OrderInfo>();
            }
             var tRapper2=DateTime.Now.Ticks;
            Console.WriteLine( " datarapper的时间: "+(tRapper2-tRapper1));
            Console.Write( " Press any key to continue . . .  ");
            Console.ReadKey( true);
        }
    }
}

 测试结果图:

 驳Fish的ORM性能问题.如有疑问大家公测.

//

 

你可能感兴趣的:(orm)