正则表达式 将SQL条件的左边字段和右边值分别取出来

sql事例:select * from table1 where a1=221 and b2=33 and c3 in (1,2,3) and d5<44 and (e1=6 or f2=8)


正则: ([^()\s]+)(?:[=<>]{1,2}|\s*in\s*)(?<a>\()?([^()\s]+)(?(a)\))

或者: (\w+)(?:=|in\(|<)([\d,]+)


匹配等号左右两边有空格的情况: ([^()\s]+)\s*(?:[=<>]{1,2}|\s*in\s*)\s*(?<a>\()?([^()\s;]+)(?(a)\))


继续改进:([^()\s]+)\s*(?>[=<>]{1,2}|in|like)\s*(?<a>\()?((?(a)[^;.()]+|[^\s;.()]+)(?<b>\()?(?(b)[^;.()]*|[^\s;.()]*)(?(b)\)))(?(a)\))(?=[\s)])[\s)]*(and|or)?\b


都是大神的杰作,仅供参考!

相关文章

正则替换html代码中img标签的src值在开发富文本信息在移动端...
正则表达式
AWK是一种处理文本文件的语言,是一个强大的文件分析工具。它...
正则表达式是特殊的字符序列,利用事先定义好的特定字符以及...
Python界一名小学生,热心分享编程学习。
收集整理每周优质开发者内容,包括、、等方面。每周五定期发...