/// <summary>
/// 分析sql语句中的表名
/// </summary>
/// <param name="sql">sql语句</param>
/// <returns>表名</returns>
public string AnalyseTableName(string sql)
{
string tblname = "";
try
{
Regex reg = new Regex(@"(?in)\b(INTO|FROM|Update)\b(?![^\[\]]*\])\s+(?<table>\[[^\[\]]+\]|\S+)");
MatchCollection mc = reg.Matches(sql);
foreach (Match m in mc)
{
tblname = m.Groups["table"].Value.Replace("[", "").Replace("]", ""); if (m.Groups["table"].Value.Contains("("))
{
tblname = m.Groups["table"].Value.Substring(, m.Groups["table"].Value.IndexOf("("));
}
else
{
tblname = m.Groups["table"].Value;
}
}
}
catch (Exception ex)
{
if (UseLog())
{
log.Error(ex.Message.ToString());
}
return "";
}
finally
{
this.Close();
}
return tblname;
}
//分析管理员增删改操作
public void RecordOperation(string sql, SqlParameter[] parms, string BaseMsg)
{
string UserId = "";
string UserName = "";
string UserType = ""; #region 判断操作人身份
if (Session["SysAccountID"] != null)//大后台系统管理员
{
UserId = Session["SysAccountID"].ToString();
UserName = Session["SysAccountName"].ToString();
UserType = "";
}
else if (Session["UserRight"] != null)
{
string UserRight = Session["UserRight"].ToString(); if (UserRight[].ToString() == "") //单位初始化用户
{
UserId = Session["DepartID"].ToString();
UserName = GetDepartName(Session["DepartID"].ToString());
UserType = "";
}
else if (UserRight[].ToString() == "") //系统管理员
{
UserId = Session["UserID"].ToString();
UserName = Session["UserName"].ToString();
UserType = "";
}
}
#endregion if (UserName.Length > )
{
string DetailMsg = UserName;
//BaseMsg不为空表示直接传入操作日志,不需要再分析
if (BaseMsg != "")
{
DetailMsg += BaseMsg;
InsertRecord(UserId, UserName, DetailMsg, UserType);
}
else
{
//需要查询数据库分析sql来确定操作日志内容
string tblname = AnalyseTableName(sql.Trim());
DataTable dt = GetRecordingMsg(tblname, sql.Trim().Substring(, ));
if (dt != null && dt.Rows.Count > )
{
BaseMsg = dt.Rows[]["BaseMsg"].ToString();
string ColumnName = dt.Rows[]["ColumnName"].ToString();
string ColumnValue = "";
if (ColumnName != null && ColumnName != "")
{
//如果当前是删除操作
if (sql.Trim().Substring(, ).ToLower() == "delete")
{
//查出delete语句中where子句的起始位置
int strIndex = sql.ToLower().LastIndexOf("where", sql.Length, sql.Length);
//拼接寻找主要信息的sql
string tempsql = " select " + ColumnName + " From " + tblname + " " + sql.Substring(strIndex, sql.Length - strIndex);
ColumnValue = db.QueryValue(tempsql, parms);
}
else
{
//插入或更新操作
foreach (SqlParameter p in parms)
{
if (p.ParameterName.ToLower() == "@" + ColumnName.ToLower())
{
ColumnValue = p.Value.ToString();
break;
}
}
}
}
DetailMsg += BaseMsg.Replace("<detail>", ColumnValue); //替换当前更新记录的重点信息
#region 插入操作日志
InsertRecord(UserId, UserName, DetailMsg, UserType);
#endregion
}
}
} }

过滤表名 & 拼接字符串的更多相关文章

  1. 正则表达式提取string 中的表名

    简单版本: Regex reg = new Regex(@"(?i)\bfrom\b(?![^\[\]]*\])\s+(\[[^\[\]]+\]|\S+)"); MatchColl ...

  2. oracle中字符串与表数据拼接的用法--“||”

    测试过程中,经常需要批量删除或者插入.修改一些表数据或结构,使用手工复制.粘贴其实很麻烦,所以这是我们就可以使用拼接成sql语句的方法来实现操作数据.下面先讲讲oracle中拼接符 || 的用法,如下 ...

  3. mysql拼接字符串和过滤字符的方法

    数据 id                value 1        aa<p>QL实木颗粒</p> 2        bb<p>QL实木颗粒</p> ...

  4. 使用dao时,如何同时使用动态表名和过滤字段?

    使用dao时,如何同时使用动态表名和过滤字段?  发布于 630天前  作者 wukonggg  316 次浏览  复制  上一个帖子  下一个帖子  标签: 无 如题.求样例代码 1 回复 wend ...

  5. SQL Server 动态行转列(参数化表名、分组列、行转列字段、字段值)

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 实现代码(SQL Codes) 方法一:使用拼接SQL,静态列字段: 方法二:使用拼接SQL, ...

  6. SQL Server 2008 R2——根据数据查找表名和字段名 根据脏数据定位表和字段

    =================================版权声明================================= 版权声明:原创文章 谢绝转载  请通过右侧公告中的“联系邮 ...

  7. [BILL WEI]SQL 如何将查询到的列作为表名去查询数据

    我们在做sql查询的时候,有时候需要将查询的列作为表名,去引用,然后再次查询 declare @table_name varchar(20) select @table_name=table_name ...

  8. MySQL 动态sql语句运行 用时间做表名

    1. 描写叙述 在使用数据的时候,我时候我们须要非常多数据库,并且想用时间来做表名以区分.可是MySQL在存储过程中不支持使用变量名来做表名或者列名. 比方,有一个表我们想以"2015-07 ...

  9. oracle中查询表的信息,包括表名,字段名,字段类型,主键,外键唯一性约束信息

    来源于网上整理 总结了一下oracle中查询表的信息,包括表名,字段名,字段类型,主键,外键唯一性约束信息,索引信息查询SQL如下,希望对大家有所帮助: 1.查询出所有的用户表select * fro ...

随机推荐

  1. 使用spring连接及操作mongodb3.0

    前边有一篇记录过不使用spring,直接在java代码中连接和操作mongodb数据库,这里就紧随其后记录一下使用spring的情况下,在java中简单操作mongodb.   maven导包配置: ...

  2. DHTMLX-Grid

    DHTMLX - Grid 介绍 dhtmlxGrid是一个灵活的.易于使用的JavaScript网格组件,可以创建DHTML表与丰富的编辑- sensing,固定的多行页眉和页脚,可调整大小的.可拖 ...

  3. android-23 View.java - dispatchTouchEvent源码

    public class View implements Drawable.Callback, KeyEvent.Callback, AccessibilityEventSource { /** * ...

  4. BestCoder Round #90 A.Kblack loves flag(随机数生成种子)

    A.Kblack loves flag [题目链接]A.Kblack loves flag [题目类型]水题 &题意: kblack喜欢旗帜(flag),他的口袋里有无穷无尽的旗帜. 某天,k ...

  5. Windows安装Node.Js

    1.下载https://nodejs.org/ 2.安装 3.修改环境变量,添加安装的Node.js的目录(此处似乎可以不用配置) 4.查看npm指令 关于npm介绍“Nodejs自身提供了基本的模块 ...

  6. UIScrollView 性能优化 - view转为Image

    进入做地图闹钟app,图层关系是这样的: subwayView 上先绘制线路上各个元素:线条 ,站点名称-Label,站点位置(画圆圈表示)-View.shapeLayer UIBezierPath ...

  7. HBase参数配置及说明

    版本:0.94-cdh4.2.1 hbase-site.xml配置 hbase.tmp.dir 本地文件系统tmp目录,一般配置成local模式的设置一下,但是最好还是需要设置一下,因为很多文件都会默 ...

  8. JAVA 编程规范(上)

    2016-03-20 J120-CHARLIEPAN JAVA 编程规范(上) 1.      应用范围 本规范应用于采用J2EE规范的项目中,所有项目中的JAVA代码(含JSP,SERVLET,JA ...

  9. Android Studio in OSX 提高工作效率的快捷键

    前言 本篇文章参考了<倍数提高工作效率的Android Studio>一文,快捷键基于OS X系统. OS X Yosemite 10.10.5 Android Studio 1.3.1 ...

  10. C++设计模式-Command命令模式

    Command命令模式作用:将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化:对请求排队或记录请求日志,以及支持可撤销的操作. 由于“行为请求者”与“行为实现者”的紧耦合,使用命令模式 ...