76 lines
3.0 KiB
Python
76 lines
3.0 KiB
Python
# ------------------------------------------------------------------------------
|
|
# Copyright (c) 2022, Oracle and/or its affiliates.
|
|
#
|
|
# This software is dual-licensed to you under the Universal Permissive License
|
|
# (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl and Apache License
|
|
# 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose
|
|
# either license.
|
|
#
|
|
# If you elect to accept the software under the Apache License, Version 2.0,
|
|
# the following applies:
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# https://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# ------------------------------------------------------------------------------
|
|
# run_sql_script.py
|
|
# ------------------------------------------------------------------------------
|
|
|
|
import os
|
|
import sys
|
|
import getpass
|
|
|
|
# default values
|
|
DEFAULT_MAIN_USER = "pythondemo"
|
|
DEFAULT_EDITION_USER = "pythoneditions"
|
|
DEFAULT_EDITION_NAME = "python_e1"
|
|
DEFAULT_CONNECT_STRING = "localhost/orclpdb"
|
|
DEFAULT_DRCP_CONNECT_STRING = "localhost/orclpdb:pooled"
|
|
|
|
|
|
def run_sql_script(conn, script_name, **kwargs):
|
|
statement_parts = []
|
|
cursor = conn.cursor()
|
|
replace_values = [("&" + k + ".", v) for k, v in kwargs.items()] + \
|
|
[("&" + k, v) for k, v in kwargs.items()]
|
|
script_dir = os.path.dirname(os.path.abspath(sys.argv[0]))
|
|
file_name = os.path.join(script_dir, "sql", script_name + ".sql")
|
|
print("SQL File Name: ", file_name)
|
|
for line in open(file_name):
|
|
if line.strip() == "/":
|
|
statement = "".join(statement_parts).strip()
|
|
if statement:
|
|
for search_value, replace_value in replace_values:
|
|
statement = statement.replace(search_value, replace_value)
|
|
try:
|
|
cursor.execute(statement)
|
|
except:
|
|
print("Failed to execute SQL:", statement)
|
|
raise
|
|
statement_parts = []
|
|
else:
|
|
statement_parts.append(line)
|
|
cursor.execute("""
|
|
select name, type, line, position, text
|
|
from dba_errors
|
|
where owner = upper(:owner)
|
|
order by name, type, line, position""",
|
|
owner=kwargs['user'])
|
|
prev_name = prev_obj_type = None
|
|
for name, obj_type, line_num, position, text in cursor:
|
|
if name != prev_name or obj_type != prev_obj_type:
|
|
print("%s (%s)" % (name, obj_type))
|
|
prev_name = name
|
|
prev_obj_type = obj_type
|
|
print(" %s/%s %s" % (line_num, position, text))
|