分析sql语句所有表名及其别名的正则表达式

最近为了 写一个分布式的数据组件构想了很多的方案,最近一个简单易行的方案终于在脑袋里成型。昨晚想到凌晨1点多,发现方案虽简单,但所有的数据库工具就不能使用了 。除非自己写一下查询分析器来执行程序员自己的维护语句。

说做就做,事情也出乎顺利,居然半天时间做了一个基本的版本出来了:)

 

于是就想想能否加上智能提示字段。似乎难在分析程序员录入的语法。当然说白了也简单就是取出表的别名。家里的空调没钱换,为了省100大元,还要晚几天才有得用。于是今晚继续晚点睡,把这个正则表达式弄出来,明天上班就能继续开发查询分析器了。

 

事情也没有想象的复杂,不到半小时,正则表达式整理出来了。利用下面的两个正则应就能分析出语法中的表名和其别名

\s+from\s+(\w+)\s+(\w+)\s+(where|left|join|inner)

\s+join\s+(\w+)\s+(\w+)\s+on

 

为了测试方便我使用了Combox来保存整理出来的表达式,于是取所有表和别名的代码是这样的

复制代码
            DataTable table = new DataTable();
            table.Columns.Add("tableName");
            table.Columns.Add("aliasName");
            foreach (string str in this.comboBox1.Items)
            {
                Regex reg = new Regex(str);
                MatchCollection mces = reg.Matches(this.richTextBox1.Text);
                foreach (Match mc in mces)
                {
                    DataRow row = table.NewRow();
                    row["tableName"] = mc.Groups[1].Value;
                    row["aliasName"] = mc.Groups[2].Value;
                    table.Rows.Add(row);
                }
            }
            this.dataGridView1.DataSource = table.DefaultView;
复制代码

以下是我用于测试的sql

select * from Outvisit l
left join patient p on l.patid=p.patientid
join patstatic c on   l.patid=c.patid inner join patphone  ph  on l.patid=ph.patid
where l.name='kevin' and exsits(select 1 from pharmacywestpas p where p.outvisitid=l.outvisitid)
unit all
select * from invisit v where

最后是我测试的小程序的截图

 

posted @   生命体验之kevin-Y  阅读(8034)  评论(1编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
历史上的今天:
2008-09-19 [Addin]OnConnection的执行时机
点击右上角即可分享
微信分享提示