Sql Server数据库监听 c#代码

复制代码
using AnfiniL.SqlServerTools.Data;
using SqlServerTools;
using SqlServerTools.Data;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Net;
using System.Text;

namespace windowsApiAcitonSimulation.Help
{
    public class DBProfiler
    {
        public static void StartSqlServerProfiler()
        {
            IProfiler profiler = ToolsFactory.Instance.CreateProfiler("192.168.0.83,9920", "sa", "zdsoft123", null);
            profiler.Initialize(TraceOptions.FileRollover, DateTime.Now.ToString(".yyyy.MM.dd.HH.mm.ss"));
            var TraceFieldArr = new TraceField[] {
                    TraceField.TextData,
                   TraceField.StartTime,
                   TraceField.Writes,
                   TraceField.Reads,
                   TraceField.ApplicationName
                };
            TraceEventProperties eventPropSql = new TraceEventProperties()
            {
                Event = TraceEvent.SQLBatchCompleted,
                Fields = TraceFieldArr
            };
            TraceEventProperties eventPropSP = new TraceEventProperties()
            {
                Event = TraceEvent.RPCCompleted,
                Fields = TraceFieldArr
            };
            profiler.AddTraceEvent(eventPropSql.Event, eventPropSql.Fields);
            profiler.AddTraceEvent(eventPropSP.Event, eventPropSP.Fields);
            var filter = new FilterProperties(
                   TraceField.ApplicationName,
                   (ComparisonOperator)Enum.Parse(typeof(ComparisonOperator), "Equal"),
                   "cszhidacysoft");
            if (filter.CheckFilter())
            {
                profiler.AddTraceFilter(filter.Field, LogicalOperator.AND, filter.Operator, filter.TypedValue);
            }
            profiler.TraceEvent += profiler_TraceEvent;
            profiler.Start();
        }
        private static void profiler_TraceEvent(object sender, TraceEventArgs e)
        {
            if (e.EventsTable.Rows.Count > 0)
            {
                foreach (DataRow row in e.EventsTable.Rows)
                {
                    if (row["TextData"].ToString().IndexOf("insert into ba_consume(vcvipno,vcNo,vcCust_c,vcCust_n,iPeople,vcTable_c,vcTable_n,vcTimes,vcServer,dtTime,vcMemo,vcOper,dtOper,vcSaler,cType,bPrint,vcID)") > -1
                        ||
                        row["TextData"].ToString().IndexOf("delete from ba_consume where") > -1
                        )
                    {
                        //此时通知用户开台列表有变动
                        string url = "http://localhost:62123/api/server/GetKTChange";
                        WebClient client = new WebClient();
                        //上传并接收数据
                        string result = client.DownloadString(url);
                        break;
                    }
                    //insert into ba_consume_d(zsr,jb,costprice,jstcmny,jsmc,isdz,szsj,jsbm,tcbm,tcsl,tcdj,tcpkid,ddlx,vcNo,vcCode,vcName,fNumber,fNumber_s,vcUnit,mPrice,mMoney,iAgio,vcMemo,vcChoose,vcClass,vcPrint,dtChoose,vcEnter,bPrint,addmoney)
                    if (row["TextData"].ToString().IndexOf("insert into ba_consume_d(zsr,jb,costprice,jstcmny,jsmc,isdz,szsj,jsbm,tcbm,tcsl,tcdj,tcpkid,ddlx,vcNo,vcCode,vcName,fNumber,fNumber_s,vcUnit,mPrice,mMoney,iAgio,vcMemo,vcChoose,vcClass,vcPrint,dtChoose,vcEnter,bPrint,addmoney)") > -1
                        ||
                         row["TextData"].ToString().IndexOf("delete from ba_consume_d") > -1
                        )
                    {
                        //点菜操作
                        //此时通知用户点菜列表有变动
                        string url = "http://localhost:62123/api/server/GetDCChange";
                        WebClient client = new WebClient();
                        //上传并接收数据
                        string result = client.DownloadString(url);
                        break;
                    }
                }
            }
        }
    }
}
复制代码

依赖:

https://files.cnblogs.com/files/gaocong/SqlServerTools.rar

posted @   小小高  阅读(3847)  评论(1编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
历史上的今天:
2017-04-25 工厂方法模式
2017-04-25 简单工厂模式
2017-04-25 正则表达式练习2017年4月25日 11:41:23
2017-04-25 LandMVC HttpHandler web.config配置
2017-04-25 在其模块列表中有一个错误模块“ManagedPipelineHandler”。
点击右上角即可分享
微信分享提示