RDIFramework.NET ━ .NET快速信息化系统开发框架 V3.2->新增记录SQL执行过程

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

有时我们需要记录整个系统运行的SQL以作分析,特别是在上线前这对我们做内部测试也非常有帮助,当然记录SQL的方法有很多,也可以使用三方的组件。3.2版本我们在框架底层新增了记录框架运行的所有SQl过程保存到用户指定的地方以便分析查看,只需要在配置文件把配置项”LogSQL”设置为True即可。框架会自动记录各常用数据库如:Oracle、SqlServer、MySQL等的操作情况。
一、Web记录Sql执行情况
1、在我们的Web项目中要记录SQL可以在Web的配置文件中设置LogSql配置项为True,默认为False,配置文件的位置MVC项目是在RDIFramework.MvcApp项目根目录下的XmlConfig文件夹下的system.config文件,WebForm项目是在RDIFramework.WebApp项目根目录下的Web.Config文件,设置配置项如下图所示:

  只要设置LogSQL为True,框架就会自动记录所有Sql执行过程并保存到指定目录,一般默认在Web项目根目录的Log文件夹下,如下图:

 

  2、查看记录的Sql。

  打开一个文件,查年记录的Sql情况,如下:

  二、WinForm记录Sql执行情况

  WinForm项目记录Sql与Web类似,一样的要修改Config.xml中的记录Sql的配置项,如下图所示。

  通过上面的配置后,一样的我们打开框架做一些操作后查看记录的Sql情况,如下图:

  三、公共方法调用

  如果我们需要单独记录sql的执行情况,可以调用框架提供的公共接口,如下图所示:

  下面把写日志的三个公共接口分享,需要的可以参考哟。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#region public virtual void WriteLog(string commandText, string fileName = null) 写入sql查询句日志
         /// <summary>
         /// 写入sql查询句日志
         /// </summary>
         /// <param name="commandText"></param>
         public  virtual  void  WriteLog( string  commandText)
         {
             string  fileName = DateTime.Now.ToString(SystemInfo.DateFormat) +  " _ "  this .FileName;
             WriteLog(commandText, fileName);
         }
 
         /// <summary>
         /// 写入sql查询句日志
         /// </summary>
         /// <param name="commandText">异常</param>
         /// <param name="fileName">文件名</param>
         public  virtual  void  WriteLog( string  commandText,  string  fileName =  null )
         {
             if  ( string .IsNullOrEmpty(fileName))
             {
                 fileName = DateTime.Now.ToString(SystemInfo.DateFormat) +  " _ "  this .FileName;
             }
             string  returnValue =  string .Empty;
             // 系统里应该可以配置是否记录异常现象
             if  (!SystemInfo.LogSQL)
             {
                 return ;
             }
             // 将异常信息写入本地文件中
             string  logDirectory = SystemInfo.StartupPath +  @"\\Log\\Query" ;
             if  (!System.IO.Directory.Exists(logDirectory))
             {
                 System.IO.Directory.CreateDirectory(logDirectory);
             }
             string  writerFileName = logDirectory +  "\\"  + fileName;
             if  (!File.Exists(writerFileName))
             {
                 FileStream FileStream =  new  FileStream(writerFileName, FileMode.Create, FileAccess.ReadWrite, FileShare.ReadWrite);
                 FileStream.Close();
             }
             StreamWriter streamWriter =  new  StreamWriter(writerFileName,  true , Encoding.Default);
             streamWriter.WriteLine(DateTime.Now.ToString(SystemInfo.DateTimeFormat) +  " "  + commandText);
             streamWriter.Close();
         }
 
         public  virtual  void  WriteLog( string  commandText, IDbDataParameter[] dbParameters =  null string  fileName =  null )
         {
             // 系统里应该可以配置是否记录异常现象
             if  (!SystemInfo.LogSQL)
             {
                 return ;
             }
             if  ( string .IsNullOrEmpty(fileName))
             {
                 fileName = DateTime.Now.ToString(SystemInfo.DateFormat) +  " _ "  + FileName;
             }
             string  message =  string .Empty;
             message = DateTime.Now.ToString(SystemInfo.DateTimeFormat) + System.Environment.NewLine +  "commandText内容"  + System.Environment.NewLine + commandText;
             if  (dbParameters !=  null )
             {
                 StringBuilder sb =  new  StringBuilder();
                 foreach  ( var  parameter  in  dbParameters)
                 {
                     sb.AppendLine(parameter.ParameterName +  "="  + parameter.Value);
                 }
                 message += System.Environment.NewLine +  "dbParameters内容"  + System.Environment.NewLine + sb.ToString();
             }
             string  logDirectory = SystemInfo.StartupPath +  @"\Log\Query" ;
             if  (!System.IO.Directory.Exists(logDirectory))
             {
                 System.IO.Directory.CreateDirectory(logDirectory);
             }
             string  writerFileName = logDirectory +  "\\"  + fileName;
             if  (!File.Exists(writerFileName))
             {
                 FileStream FileStream =  new  FileStream(writerFileName, FileMode.Create, FileAccess.ReadWrite, FileShare.ReadWrite);
                 FileStream.Close();
             }
             StreamWriter streamWriter =  new  StreamWriter(writerFileName,  true , Encoding.Default);
             streamWriter.WriteLine(DateTime.Now.ToString(SystemInfo.DateTimeFormat) +  " "  + message);
             streamWriter.Close();
         }
         #endregion

 



本文转自yonghu86博客园博客,原文链接:http://www.cnblogs.com/huyong/p/6490609.html,如需转载请自行联系原作者

相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
3月前
|
前端开发 JavaScript 关系型数据库
使用 OpenAuth.Net 快速搭建 .NET 企业级权限工作流系统
使用 OpenAuth.Net 快速搭建 .NET 企业级权限工作流系统
125 0
|
2月前
|
SQL 容灾 安全
云时代SQL Server的终极答案:阿里云 RDS SQL Server如何用异地容灾重构系统可靠性
在数字化转型的浪潮中,数据库的高可用性已成为系统稳定性的生命线。作为经历过多次生产事故的资深开发者,肯定深知传统自建SQL Server架构的脆弱性——直到遇见阿里云 RDS SQL Server,其革命性的异地容灾架构彻底改写了游戏规则。
|
6月前
|
SQL 小程序 API
如何运用C#.NET技术快速开发一套掌上医院系统?
本方案基于C#.NET技术快速构建掌上医院系统,结合模块化开发理念与医院信息化需求。核心功能涵盖用户端的预约挂号、在线问诊、报告查询等,以及管理端的排班管理和数据统计。采用.NET Core Web API与uni-app实现前后端分离,支持跨平台小程序开发。数据库选用SQL Server 2012,并通过读写分离与索引优化提升性能。部署方案包括Windows Server与负载均衡设计,确保高可用性。同时针对API差异、数据库老化及高并发等问题制定应对措施,保障系统稳定运行。推荐使用Postman、Redgate等工具辅助开发,提升效率与质量。
228 0
|
10月前
|
前端开发 C# 开发者
.NET使用Umbraco CMS快速构建一个属于自己的内容管理系统
.NET使用Umbraco CMS快速构建一个属于自己的内容管理系统
139 12
|
10月前
|
Web App开发 前端开发 调度
一款基于 .NET + Blazor 开发的智能访客管理系统
一款基于 .NET + Blazor 开发的智能访客管理系统
156 8
|
10月前
|
开发框架 JavaScript 前端开发
精选2款.NET开源的博客系统
精选2款.NET开源的博客系统
135 8
|
10月前
|
前端开发 JavaScript C#
基于.NET8+Vue3开发的权限管理&个人博客系统
基于.NET8+Vue3开发的权限管理&个人博客系统
139 7
|
11月前
|
开发框架 安全 Java
.NET技术的独特魅力与优势,涵盖高效的开发体验、强大的性能表现、高度的可扩展性及丰富的生态系统等方面,展示了其在软件开发领域的核心竞争力
本文深入探讨了.NET技术的独特魅力与优势,涵盖高效的开发体验、强大的性能表现、高度的可扩展性及丰富的生态系统等方面,展示了其在软件开发领域的核心竞争力。.NET不仅支持跨平台开发,具备出色的安全性和稳定性,还能与多种技术无缝集成,为企业级应用提供全面支持。
351 3
|
12月前
|
关系型数据库 C# 数据库
.NET 8.0 开源在线考试系统(支持移动端)
【10月更文挑战第27天】以下是适用于 .NET 8.0 的开源在线考试系统(支持移动端)的简介: 1. **基于 .NET Core**:跨平台,支持多种数据库,前后端分离,适用于多操作系统。 2. **结合 Blazor**:使用 C# 开发 Web 应用,支持响应式设计,优化移动端体验。 3. **基于 .NET MAUI**:跨平台移动应用开发,一套代码多平台运行,提高开发效率。 开发时需关注界面设计、安全性与稳定性。
325 4