ASP.NET中显示Linq To SQL输出的SQL语句
2009-06-14 20:34
603 查看
最近在使用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语句。
如果是在桌面程序中,只需要
_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 MVC 模型(Entity Framework、LinqToSql、显示数据库数据表格)
- asp.net使用LINQ to SQL连接数据库及SQL操作语句用法分析
- Asp.net MVC 模型(Entity Framework、LinqToSql、显示数据库数据表格)
- asp.net MVC+ LINQ to Entities简单添加,修改,删除,显示,子查询
- LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL
- ASP.NET网站开发——LINQ TO SQL 动态数据支持
- Asp.net网站开发(一)LINQ TO SQL 之动态数据支持
- 如何在 ASP.NET项目里面正确使用Linq to Sql(转)
- asp.net3.0新特性研究一Linq To Sql集成数据库语言的优点和缺点 (1)
- LinqToSql和ASP.NET Entity FrameWork 中使用事务
- Asp.Net MVC结合Linq to SQL实现CRUD
- ExtJs、ASP.net运用Linq to SQL与SQL储存过程交互(转)
- Microsoft ASP.NET MVC Preview 5 及LINQ TO SQL最新版开发示例演示(提供源码下载)
- Microsoft ASP.NET MVC Preview 5 及LINQ TO SQL最新版开发示例演示(提供源码下载)
- LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL
- ASP.NET网站开发——LINQ to SQL 类动态数据支持
- ASP.NET网站开发中的LINQ to SQL与数据上下文
- ASP.NET------LINQ to SQL
- LINQ体验(13)——LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL