clowwindy的杂草牧场

   :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
  34 随笔 :: 1 文章 :: 75 评论 :: 13万 阅读

最近在使用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,用来显示日志:

复制代码
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Log.aspx.cs" Inherits="Clowwindy.Log" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    
<title>SQL Log</title>
</head>
<body>
    
<form id="form1" runat="server">
    
<asp:Button ID="btn_Clean" runat="server" Text="清空" 
        onclick
="btn_Clean_Click"/>
    
<div>
        
<asp:Literal ID="Literal1" runat="server"></asp:Literal>
    
</div>
    
</form>
</body>
</html>
复制代码

 

复制代码
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()
        {
            _context 
= new TDataContext();
            _context.Log 
= LogHelper.In;
        }
复制代码

 

 打开log.aspx,即可看到之前执行的SQL语句。

posted on   clowwindy  阅读(3048)  评论(5编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
点击右上角即可分享
微信分享提示