35 lines
1.3 KiB
Python
35 lines
1.3 KiB
Python
#------------------------------------------------------------------------------
|
|
# Copyright (c) 2016, 2021, Oracle and/or its affiliates. All rights reserved.
|
|
#
|
|
# Portions Copyright 2007-2015, Anthony Tuininga. All rights reserved.
|
|
#
|
|
# Portions Copyright 2001-2007, Computronix (Canada) Ltd., Edmonton, Alberta,
|
|
# Canada. All rights reserved.
|
|
#------------------------------------------------------------------------------
|
|
|
|
#------------------------------------------------------------------------------
|
|
# database_shutdown.py
|
|
# This script demonstrates shutting down a database using Python. The
|
|
# connection used assumes that the environment variable ORACLE_SID has been
|
|
# set.
|
|
#
|
|
# This script requires cx_Oracle 4.3 and higher.
|
|
#------------------------------------------------------------------------------
|
|
|
|
import cx_Oracle as oracledb
|
|
|
|
# need to connect as SYSDBA or SYSOPER
|
|
connection = oracledb.connect(mode=oracledb.SYSDBA)
|
|
|
|
# first shutdown() call must specify the mode, if DBSHUTDOWN_ABORT is used,
|
|
# there is no need for any of the other steps
|
|
connection.shutdown(mode=oracledb.DBSHUTDOWN_IMMEDIATE)
|
|
|
|
# now close and dismount the database
|
|
cursor = connection.cursor()
|
|
cursor.execute("alter database close normal")
|
|
cursor.execute("alter database dismount")
|
|
|
|
# perform the final shutdown call
|
|
connection.shutdown(mode=oracledb.DBSHUTDOWN_FINAL)
|