淺談如何在ASP.NET中了解LINQ語(yǔ)句性能
作者:clowwindy
作者最近在使用Linq To SQL的時(shí)候,為了了解不同Linq語(yǔ)句對(duì)性能造成的不同影響,需要獲得Linq To SQL生成的SQL語(yǔ)句。為了實(shí)現(xiàn)這一功能,作者創(chuàng)建了一些小工具,供大家使用。
如果是在桌面程序中,只需要
_context.Log = Console.Out; |
即可在控制臺(tái)輸出SQL語(yǔ)句??墒窃贏SP.NET中又該怎么辦呢?
這時(shí)我想起了StringWriter。用它就可以代替Console.Out幫我們接收輸出的日志,保存在一個(gè)StringBuilder里。
于是構(gòu)造一個(gè)輔助類(lèi):
using System; |
再添加一個(gè)頁(yè)面log.aspx,用來(lái)顯示日志:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Log.aspx.cs" Inherits="Clowwindy.Log" %> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> |
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Clowwindy.Models;
namespace Clowwindy
{
public partial class Log : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (Request.UserHostAddress != "127.0.0.1")
{
Response.End();
return;
}
Literal1.Text = LogHelper.GetAllLog().Replace("\n","\n<br/>");
}
protected void btn_Clean_Click(object sender, EventArgs e)
{
LogHelper.Clean();
Literal1.Text = null;
}
}
}
***在所有new DataContext的地方加上_context.Log = LogHelper.In:
public Repository() |
打開(kāi)log.aspx,即可看到之前執(zhí)行的SQL語(yǔ)句。
【編輯推薦】
責(zé)任編輯:彭凡
來(lái)源:
cnblogs