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

前端之家收集整理的这篇文章主要介绍了正则表达式 将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


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

猜你在找的正则表达式相关文章