Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: 支持使用create or replace创建函数、存储过程、视图以及包等语句 #2066

Merged
merged 9 commits into from
Mar 11, 2023
50 changes: 49 additions & 1 deletion sql/engines/oracle.py
Original file line number Diff line number Diff line change
Expand Up @@ -477,6 +477,42 @@ def get_sql_first_object_name(sql=""):
object_name = re.match(
r"^create\s+package\s(.+?)\s", sql, re.M | re.IGNORECASE
).group(1)
elif re.match(r"^create\s+type\s+body", sql, re.M | re.IGNORECASE):
object_name = re.match(
r"^create\s+type\s+body\s(.+?)\s", sql, re.M | re.IGNORECASE
).group(1)
elif re.match(r"^create\s+type\s", sql, re.M | re.IGNORECASE):
object_name = re.match(
r"^create\s+type\s(.+?)\s", sql, re.M | re.IGNORECASE
).group(1)
elif re.match(r"^create\s+or\s+replace\s+function\s", sql, re.M | re.IGNORECASE):
object_name = re.match(
r"^create\s+or\s+replace\s+function\s(.+?)(\s|\()", sql, re.M | re.IGNORECASE
).group(1)
elif re.match(r"^create\s+or\s+replace\s+view\s", sql, re.M | re.IGNORECASE):
object_name = re.match(
r"^create\s+or\s+replace\s+view\s(.+?)(\s|\()", sql, re.M | re.IGNORECASE
).group(1)
elif re.match(r"^create\s+or\s+replace\s+procedure\s", sql, re.M | re.IGNORECASE):
object_name = re.match(
r"^create\s+or\s+replace\s+procedure\s(.+?)(\s|\()", sql, re.M | re.IGNORECASE
).group(1)
elif re.match(r"^create\s+or\s+replace\s+package\s+body", sql, re.M | re.IGNORECASE):
object_name = re.match(
r"^create\s+or\s+replace\s+package\s+body\s(.+?)\s", sql, re.M | re.IGNORECASE
).group(1)
elif re.match(r"^create\s+or\s+replace\s+package\s", sql, re.M | re.IGNORECASE):
object_name = re.match(
r"^create\s+or\s+replace\s+package\s(.+?)(\s|\()", sql, re.M | re.IGNORECASE
).group(1)
elif re.match(r"^create\s+or\s+replace\s+type\s+body", sql, re.M | re.IGNORECASE):
object_name = re.match(
r"^create\s+or\s+replace\s+type\s+body\s(.+?)\s", sql, re.M | re.IGNORECASE
).group(1)
elif re.match(r"^create\s+or\s+replace\s+type\s", sql, re.M | re.IGNORECASE):
object_name = re.match(
r"^create\s+or\s+replace\s+type\s(.+?)(\s|\()", sql, re.M | re.IGNORECASE
).group(1)
LeoQuote marked this conversation as resolved.
Show resolved Hide resolved
else:
return object_name.strip()
return object_name.strip()
Expand Down Expand Up @@ -966,7 +1002,19 @@ def execute_check(self, db_name=None, sql="", close_conn=True):
object_name = object_name.upper()

object_name = f"""{schema_name}.{object_name}"""
if (
if re.match(r"^create\sor\sreplace", sql_lower) and (self.object_name_check(db_name=db_name,
object_name=object_name) or object_name in object_name_list):
result = ReviewResult(id=line, errlevel=1,
stagestatus=f"""{object_name}对象已经存在,请确认是否替换!""",
errormessage=f"""{object_name}对象已经存在,请确认是否替换!""",
sql=sqlitem.statement,
stmt_type=sqlitem.stmt_type,
object_owner=sqlitem.object_owner,
object_type=sqlitem.object_type,
object_name=sqlitem.object_name,
affected_rows=0,
execute_time=0, )
elif (
self.object_name_check(
db_name=db_name, object_name=object_name
)
Expand Down