正则表达式从SQL语句中删除注释

前端之家收集整理的这篇文章主要介绍了正则表达式从SQL语句中删除注释前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用正则表达式从sql语句中删除注释.

这个正则表达式几乎有效:

(/\*([^*]|[\r\n]|(\*+([^*/]|[\r\n])))*\*+/)|'(?:[^']|'')*'|(--.*)

除了最后一部分不能很好地处理“ – ”评论.问题是处理sql字符串,用”分隔.

例如,如果我有

SELECT ' -- Hello -- ' FROM DUAL

它不应该匹配,但它匹配.

这是在ASP / VBscript中.

我想过从右到左匹配,但我不认为VBScript的正则表达式引擎支持它.也试图摆弄负面的背后,但结果并不好.

PHP中,我使用此代码取消注释sql
$sqlComments = '@(([\'"]).*?[^\\\]\2)|((?:\#|--).*?$|/\*(?:[^/*]|/(?!\*)|\*(?!/)|(?R))*\*\/)\s*|(?<=;)\s+@ms';
/* Commented version
$sqlComments = '@
    (([\'"]).*?[^\\\]\2) # $1 : Skip single & double quoted expressions
    |(                   # $3 : Match comments
        (?:\#|--).*?$   # - Single line comments
        |                # - Multi line (nested) comments
         /\*             #   . comment open marker
            (?: [^/*]    #   . non comment-marker characters
                |/(?!\*) #   . ! not a comment open
                |\*(?!/) #   . ! not a comment close
                |(?R)    #   . recursive case
            )*           #   . repeat eventually
        \*\/             #   . comment close marker
    )\s*                 # Trim after comments
    |(?<=;)\s+           # Trim after semi-colon
    @msx';
*/
$uncommentedsql = trim( preg_replace( $sqlComments,'$1',$sql ) );
preg_match_all( $sqlComments,$sql,$comments );
$extractedComments = array_filter( $comments[ 3 ] );
var_dump( $uncommentedsql,$extractedComments );

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