【正则】构造复杂SQL语句的正则表达式2(粗粒度分析)
(二)语句构造粗粒度分析以下分析oracleSQL语法为例进行分析。
Select语句构造粗粒度分析
排除Oracle特有的语法,从上可以看出select语句可以分为5部分1.select后面出现的内容可以是from后面的数据源中的列,也可以是*、常量、表达式或者函数。
2.如果列名很长或者多个表的列名有冲突,使用as来定义别名。
3.列中可能出现子查询。1.数据源可以是表、视图、子查询,对于可能冲突表名或为了简写表名,可以使用as别名。
2.From_Clause可以包含连接说明,InnerJoin、OutterJoin等。条件子句比较复杂,包含类型比较多,以下是常用的类型:
1.复合条件表达式:多个表达式通过And或or连接。
2.比较表达式:类似于A=B包括>,>=、,IS(not)NULL。
3.逻辑表达式:除了andor之外,还有not
4.模式匹配表达式:Alike"%%"
5.范围表达式:Abetween10andB
6.In或者Exists表达式select语句中出现的列,都必须出现在groupby子句中,除非那一列使用了聚集函数。
having子句是从分组后的结果中筛选行,having的搜索条件在进行分组操作之后应用,所以它必须在groupby之后使用。它和where子句的另一个区别在于,它可以出现聚合函数。
where和having中都可以出现比较运算符,between,in,like,all,any。orderbycolumns用来对结果集进行排序,按照列顺序,嵌套排序。默认是asc升序,desc是降序。