欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【ASP.NET中显示Linq To SQL输出的SQL语句】,下面是详细的分享!
ASP.NET中显示Linq To SQL输出的SQL语句
最近在使用Linq To SQL的时候,为了了解不同Linq语句对性能造成的不同影响,需要获得Linq To SQL生成的SQL语句。
如果是在桌面程序中,只需要
_context.Log=Console.Out;
即可在控制台输出SQL语句。可是在ASP.NET中又该怎么办呢?
这时我想起了StringWriter。用它就可以代替Console.Out帮我们接收输出的日志,保存在一个StringBuilder里。
于是构造一个辅助类:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.IO;
using System.Text;
namespace Clowwindy.Models
{
public static class LogHelper
{
public static StringBuilder Log=new StringBuilder();
public static TextWriter In=new StringWriter(Log);
public static string GetAllLog()
{
In.Flush();
return Log.ToString();
}
public static void Clean()
{
Log=new StringBuilder();
In=new StringWriter(Log);
}
}
}
再添加一个页面log.aspx,用来显示日志:
onclick="btn_Clean_Click"/>
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
");
}
protected void btn_Clean_Click(object sender, EventArgs e)
{
LogHelper.Clean();
Literal1.Text=null;
}
}
}
最后在所有new DataContext的地方
加上_context.Log=LogHelper.In:
public Repository()
{
_context=new TDataContext();
_context.Log=LogHelper.In;
}
打开log.aspx,即可看到之前执行的SQL语句。
以上所分享的是关于ASP.NET中显示Linq To SQL输出的SQL语句,下面是编辑为你推荐的有价值的用户互动:
相关问题:asp.net的CS文件中使用SQL语句查询
答:String sql=”select NewsLists.*,ClerkInfors.职员姓名 from NewsLists left join ClerkInfors on NewsLists.NeClerkID=ClerkInfors.ClerkID where NewsLists.NeClerkID=@NeClerkID "; >>详细
相关问题:怎么查看linq产生的sql语句
答:class table { public string id } private void Window_Loaded(object sender, RoutedEventArgs e) { List ls = new List(); for (int i = 0; i < 10; i++) ls.Add(new table ); int pageSize = 3; int currentPage = 2; var linq = (from t in... >>详细
相关问题:asp.net怎么读取数据库sql语句执行结果
答:第一种方法: //建立ASP.NET Web 应用程序,直接在Page_load函数中加入一下代码,貌似就可以用了 public void Page_Load(object sender, EventArgs e) { using (SqlConnection con = new SqlConnection("Data Source=.;uid=sa;pwd=sa;Database=N... >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
