c# 怎么获取所执行的sql查询语句的真实表名

所执行的查询语句时隔变量,怎么才能获取到所执行的查询语句中的真是表名,dataset是不可能的了datareader可是吗?上面第一句话的‘时隔’是打错的,应该是‘是个’... 所执行的查询语句时隔变量,怎么才能获取到所执行的查询语句中的真是表名,dataset是不可能的了 datareader可是吗?
上面第一句话的‘时隔’是打错的,应该 是‘是个’
展开
 我来答
xeonol
2011-01-20 · TA获得超过870个赞
知道小有建树答主
回答量:528
采纳率:0%
帮助的人:707万
展开全部
一个简单的sql很容易,不过sql查询语句可能会包括联合多个表,以及子查询之类的,你的要求是不是要找出sql语句中的全部的表名?如果那样可以用正则表达式,你可以试试,如果解不了可以ping我

a simple regular expression:
string sql = "select * from table";
System.Text.RegularExpressions.Regex rg = new System.Text.RegularExpressions.Regex(@"from[\s]+([\w]+)[\s]*");
System.Text.RegularExpressions.MatchCollection mc = rg.Matches(sql);
foreach (System.Text.RegularExpressions.Match m in mc)
{
System.Diagnostics.Debug.Print(m.Groups[1].Value);
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
pnq32742
2011-01-19 · TA获得超过1179个赞
知道小有建树答主
回答量:1436
采纳率:0%
帮助的人:1196万
展开全部
你试试这样行不?如果行就接点分

int i1,i2;
i1=this.TextBox1.Text.Trim().IndexOf("from" )+4; //from 中F的位置.
i2=this.TextBox1.Text.Trim().IndexOf("where");
//加入判断是否有where的代码
if (i2<0) i2=this.TextBox1.Text.Trim().Length;

string sql="select * from "+this.TextBox1.Text.Trim().Substring(i1,i2-i1);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
辱照
2011-01-20
知道答主
回答量:24
采纳率:0%
帮助的人:0
展开全部
用正则表达式吧
但如果是简单sql,pnq32742的方法也行
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
dawncoasting
2011-01-19
知道答主
回答量:9
采纳率:0%
帮助的人:0
展开全部
不理解你的意思
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式