zoukankan      html  css  js  c++  java
  • oracle杀用户建用户改密码脚本

    # ********************************
    # * dba_oracle_awr.sh
    # ********************************
    # Usage: dba_oracle_awr.sh -s [instance_name]
    # -f [from time]
    # -t [to time]
    # -p [report type, html or text]
    # -h [oracle home]
    # -n [tns admin]
    #
    # time format: 'yyyymmddhh24miss'.
    # E.g 20110304170000 means 05:00:00pm, Mar 04, 2011
    #
    #
    # **********************
    # get parameters
    # **********************
    while getopts ":i:s:" opt
    do
    case $opt in
    i) instance=$OPTARG
    ;;
    s) schemaName=$OPTARG
    ;;
    '?') echo "$0: invalid option -$OPTARG">&2
    exit 1
    ;;
    esac
    done
    
    oracle_home=$ORACLE_HOME
    if [ "$instance" = "" ]
    then
    echo "instance name(-i) needed"
    echo "program exiting..."
    exit 1
    fi
    if [ "$schemaName" = "" ]
    then
    echo "report_name name (-s} needed"
    echo "program exiting..."
    exit 1
    fi
    
    sqlplus="${oracle_home}/bin/sqlplus"
    echo $sqlplus
    echo "start imp dmp--------------------------------------------"
    
    # *******************************
    # get begin and end snapshot ID
    # *******************************
    lock_user()
    {
    echo "lock user: $schemaName ................"
    
    sqlplus -S /nolog<<EOF
    conn / as sysdba
    set term off
    ALTER USER $schemaName ACCOUNT LOCK;
    EOF
    }
    
    restart_db()
    {
    echo "restart DB ................"
    
    sqlplus -S /nolog<<EOF
    conn / as sysdba
    set term off
    shutdown immediate;
    startup;
    EOF
    }
    
    
    create_kill_proc()
    {
    echo "create kill proc ................"
    sqlplus -S /nolog<<EOF
    conn / as sysdba
    CREATE OR REPLACE PROCEDURE DBA_KILL_SCHEMANAME_SESSION(SCHEMA_NAME VARCHAR2) AS
    s VARCHAR2(1000);
    BEGIN
    FOR CUR IN (select s.SID, s.SERIAL#
    from v$session s
    where username = SCHEMA_NAME) LOOP
    dbms_output.put_line('ALTER SYSTEM KILL SESSION ''' || CUR.SID || ',' || CUR.SERIAL# || '''');
    s := 'ALTER SYSTEM KILL SESSION ''' || CUR.SID || ',' || CUR.SERIAL# || '''';
    EXECUTE IMMEDIATE S;
    END LOOP;
    END;
    /
    EOF
    }
    
    exec_kill_proc()
    {
    echo "kill session ................"
    
    sqlplus -S /nolog<<EOF
    conn / as sysdba
    exec DBA_KILL_SCHEMANAME_SESSION('$schemaName');
    EOF
    }
    
    
    lock_user()
    {
    echo "lock user ................"
    
    sqlplus -S /nolog<<EOF
    conn / as sysdba
    ALTER USER $schemaName ACCOUNT LOCK;
    EOF
    }
    
    unlock_user()
    {
    echo "unlock user ................"
    
    sqlplus -S /nolog<<EOF
    conn / as sysdba
    ALTER USER $schemaName ACCOUNT UNLOCK;
    EOF
    }
    
    
    del_user()
    {
    echo "drop user: $schemaName ................"
    
    sqlplus -S /nolog<<EOF
    conn / as sysdba
    set term off
    DROP USER $schemaName CASCADE;
    EOF
    }
    # *******************************
    # generate AWR report
    # *******************************
    create_user()
    {
    echo "create user: $schemaName ................"
    
    sqlplus -S /nolog<<EOF
    conn / as sysdba
    set term off
    CREATE USER $schemaName
    IDENTIFIED BY VALUES '$schemaName'
    DEFAULT TABLESPACE TRADE
    TEMPORARY TABLESPACE TEMP
    PROFILE DEFAULT
    ACCOUNT UNLOCK;
    GRANT CONNECT TO $schemaName;
    GRANT IMP_FULL_DATABASE TO $schemaName;
    GRANT PLUSTRACE TO $schemaName;
    GRANT RESOURCE TO $schemaName;
    ALTER USER $schemaName DEFAULT ROLE ALL;
    GRANT ADVISOR TO $schemaName;
    GRANT UNLIMITED TABLESPACE TO $schemaName;
    GRANT EXECUTE ON SYS.DBMS_FGA TO $schemaName;
    GRANT READ, WRITE ON DIRECTORY SYS.MY_EXPDP_DUMP TO $schemaName;
    EOF
    }
    
    # *******************************
    # main routing
    # *******************************
    change_pwd()
    {
    echo "change passwd................"
    sqlplus -S /nolog<<EOF
    conn / as sysdba
    set term off
    alter user $schemaName identified by howbuy_qa_qwerVBNM;
    EOF
    }
    
    
    #restart_db
    
    lock_user
    #create_kill_proc
    exec_kill_proc
    del_user
    create_user
    change_pwd

    保存为imp.sh

    调用

     ./imp.sh  -i ORCL -s ${toUser}_${dataBase}

    (必须大写,因为数据库会话名称都是大写)

  • 相关阅读:
    hive之窗口函数
    linux环境下Mysql的卸载和重新安装和启动
    2017ACM暑期多校联合训练
    2017ACM暑期多校联合训练
    状态压缩dp
    铺砖问题 (状态压缩dp)
    POj 2104 K-th Number (分桶法+线段树)
    POJ 2991 Crane (线段树)
    4 Values whose Sum is 0 POJ 2785 (折半枚举)
    Billboard HDU 2795 (线段树)
  • 原文地址:https://www.cnblogs.com/xianlai-huang/p/5997037.html
Copyright © 2011-2022 走看看