• 一个用Regex的完成sql语句中字段替换的demo


     

    这两天在小demo。功能实现的是在一个template中(string Type,实际上是一个SQL select查询语句),用正则表达式查询出符合条件的字段,然后用另外一些值替换成实际可用的查询语句,然后显示出来。

    因为开始需求自已弄的还不是很明白。所以琢磨了一阵,才理出思路。

    大概实现步骤的思路是:

    1、            因为template是在一个arrayinfo里的,所以先找到arrayinfo,然后再找到arrayinfo包含的template,并取出此值并赋给另一个string类型的变量(这样做只是看得清晰些);

                    IEnumerator IEatorArrayinfoList = arrayinfo.GetEnumerator();

                     while (IEatorArrayinfoList.MoveNext())

                     {

                         RuleTypeInfo ruleInfo = (RuleTypeInfo)IEatorArrayinfoList.Current;

                         if (cboRuleType.SelectedValue.ToString() == ruleInfo.RuleTypeID.ToString())

                         {

                             strSelect = ruleInfo.RuleTypeTemplate;

                         }

          }

    2、            使用正则表达式(Regex)。使用正则表达式的时候费了一些时间,因为之间学的都忘记得干干净净的了。只好又找了一篇文章《正则表达式30入门教程》,因为此文写得比较基础,而且通俗易懂,大概意思是理解了,但是实际操作起来还是有点困难。所以又在琢磨了一些时候,才将两个正则表达式写出来,并添加到ArrayList中,与所需求的是一样的。
     //获取需替代的字段

            public static ArrayList showMatches(string expression, RegexOptions option, string ms)

            {

                Regex regex = new Regex(expression, option);

                MatchCollection matches = regex.Matches(ms);

                ArrayList list = new ArrayList();

                foreach (Match m in matches)

                {

                    list.Add(m.ToString());

                }

                return list;

    }

       //获取用正则表达式取出的字段(一种带&.,一种只是纯粹的字段)

              listSign = showMatches(@""&"w*"d*".", RegexOptions.None, strSelect);

     listField = showMatches(@"(?<=&)"w*"d*[^&.](?=".)", RegexOptions.None, strSelect);

    3、            将即将要替换上的值的名字与值添加到HashTable里(值的名字为key,值为value)。

    //将paralist中的参数填充hashtable

                        this.gridParameters.Items.Refresh();

                        txtName.Focus();

                        IEnumerable IEnumberTableList = this.gridParameters.Items.SourceCollection;

                        IEnumerator IEatorList = IEnumberTableList.GetEnumerator();

                        while (IEatorList.MoveNext())

                        {  

                            ParamersGridInfo infoList = (ParamersGridInfo)IEatorList.Current;

                            htRulePara.Add(infoList.RuleTypeParaName, infoList.RuleTypeParaValue);

                        }

    4、            然后循环将HashTable中的key与用正则表达式查出来的字段(ArrayList[i])对比,如果相同,就用string.Replace替换就可以了,然后就是一个新的SQL select查询语句了。

    //获取替换后的sql select语句

                        foreach (DictionaryEntry de in htRulePara)

                        {

                            for (int i = 0; i < listField.Count; i++)

                            {

                                if (de.Key.ToString() == listField[i].ToString())

                                {

                                    strSelect = strSelect.Replace(listSign[i].ToString(), de.Value.ToString());

                                }

                            }

                        }

                        MessageBox.Show(strSelect,Constant.SystemTitle, MessageBoxButton.OK,MessageBoxImage.Information);

  • 相关阅读:
    第2章安装和升级MySQL
    1.7.3.4 ENUM和SET约束
    1.7.3.3对无效数据的强制约束
    1.7.3.2外部关键约束
    跨浏览器的事件处理程序-读书笔记
    表单-读书笔记
    【小知识点】一条线的居中问题
    函数表达书-读书笔记
    原型链-读书笔记
    面向对象(三)-读书笔记
  • 原文地址:https://www.cnblogs.com/yiyisawa/p/1023072.html
Copyright © 2020-2023  润新知