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,如需转载请自行联系原作者

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
打赏
0
0
0
0
10
分享
相关文章
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
403 3
SQL在构建系统中的应用:关键步骤与技巧
在构建基于数据库的应用系统时,SQL(Structured Query Language)作为与数据库交互的核心语言,扮演着至关重要的角色
NL2SQL之DB-GPT-Hub<详解篇>:text2sql任务的微调框架和基准对比
NL2SQL之DB-GPT-Hub<详解篇>:text2sql任务的微调框架和基准对比
Flask 框架防止 SQL 注入攻击的方法
通过综合运用以上多种措施,Flask 框架可以有效地降低 SQL 注入攻击的风险,保障应用的安全稳定运行。同时,持续的安全评估和改进也是确保应用长期安全的重要环节。
220 71
|
3月前
|
除了Flask框架,还有哪些框架能防止SQL注入攻击?
这些框架都在安全方面有着较好的表现,通过它们的内置机制和安全特性,可以有效地降低 SQL 注入攻击的风险。然而,无论使用哪个框架,开发者都需要具备良好的安全意识,正确配置和使用框架提供的安全功能,以确保应用的安全可靠。同时,持续关注安全更新和漏洞修复也是非常重要的。
130 60
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
Vanna 是一个开源的 Python RAG(Retrieval-Augmented Generation)框架,能够基于大型语言模型(LLMs)为数据库生成精确的 SQL 查询。Vanna 支持多种 LLMs、向量数据库和 SQL 数据库,提供高准确性查询,同时确保数据库内容安全私密,不外泄。
527 7
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
Spark SQL向量化执行引擎框架Gluten-Velox在AArch64使能和优化
本文摘自 Arm China的工程师顾煜祺关于“在 Arm 平台上使用 Native 算子库加速 Spark”的分享,主要内容包括以下四个部分: 1.技术背景 2.算子库构成 3.算子操作优化 4.未来工作
137 0
XiYan-SQL:一种多生成器集成的Text-to-SQL框架
XiYan-SQL 是一种创新的多生成器集成Text-to-SQL框架,通过M-Schema增强模型对数据库结构的理解,结合ICL与SFT方法提升SQL生成质量和多样性,经实验证明在多个数据集上表现优异,特别是在Spider和SQL-Eval上取得了领先成绩。
|
4月前
|
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
126 4
SQL在构建系统中的应用:关键要素与编写技巧
在构建基于数据库的系统时,SQL(Structured Query Language)扮演着至关重要的角色

热门文章

最新文章