在使用oracle过程中,总会遇到用户锁定,密码失效等问题,对于这些问题,总结了以下经验: 一、用户被锁定原因及解锁对于用户被锁定,有以下几种原因: 1、密码过期:Oracle数据库的用户密码有效期默认180天,当超过180天后密码过期,这种情形会造成Oracle数据库用户频繁被锁定,用户需手动更改密码后解除锁定。 解决方法: 方法一:SQL语句修改 1.查看用户的proifle是哪个,一般是default SELECT username,PROFILE FROM dba_users; 2.查看对应的概要文件(如default)的密码有效期设置 SELECT * FROM dba_profiles s WHERE s.profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME'; 3.将概要文件(如default)的密码有效期由默认的180天修改成“无限制”(修改之后不需要重启动数据库,会立即生效) ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED; 4.对已经锁定和过期的账号进行解锁 (1)alter user 用户名 identified by 原来的密码 account unlock; ----不用换新密码,用户名和密码也不用加引号,这个命令会解锁账号,同时取消密码过期。 (2)alter user 用户名 account unlock; ----这个只会解锁账号,而不会取消密码过期,所以建议使用上面的口令 方法二:PL/SQL进行修改 1、打开PL/SQL,通过sys账户(系统管理员)登录 2、在左侧对象栏中查找Users文件夹下要修改的用户,右击用户,点击编辑按钮进入编辑界面
3、下图为用户详细,修改用户密码,并取消勾选口令期限和账户被锁定两项。(若口令期限勾选为灰项,不可更改时,使用方法一中第二步,根据下图显示的概要文件名称,修改概要文件的密码有效期为“无限制”)
4、修改后点击“保存”按钮,进行保存。 2、尝试多次失败登陆造成的被锁:一般数据库默认是10次尝试登录失败后锁住用户。 当用户人为手动登录失败锁定后只需解锁用户即可。 除人为手动登录失败外,有可能有第三方应用或接口调用数据库,从而用错误的账户密码频繁尝试登录系统,这种情形可能会造成Oracle数据库用户频繁被锁定,用户需查找出尝试登录的第三方应用或接口,修改为正确的登录账户及密码,之后解锁用户。 用户可以修改连接失败次数,但是此方法只能控制人工输入失误次数:
alter profile default limit FAILED_LOGIN_ATTEMPTS 30; ----修改为30次尝试失败后锁住用户。
解锁用户:
(1)alter user 用户名 identified by 原来的密码 account unlock; ----不用换新密码,用户名和密码也不用加引号,这个命令会解锁账号,同时取消密码过期。 (2)alter user 用户名 account unlock; ----这个只会解锁账号,而不会取消密码过期,所以建议使用上面的口令
二、SQLPlus登录及连接平时用习惯了PL/SQL,但是有时只能通过SQLPlus进行数据库操作时,使用时总有些不顺手。以下是几种SQLPlus的连接方式: 1、打开SQLPlus,提示输入用户名,回车键后提示输入密码,普通用户直接输入密码,sys用户输入:密码 as sysdba 2、打开SQLPlus,输入conn sys/密码 as sysdba;//以DBA的身份登录;输入conn 普通用户/密码;//以normal用户的身份登录 3、win+r键打开运行,输入"cmd"打开"命令提示符"(也可从所有程序>>附件中打开)。输入或
进行连接。(其中dgyzt为用户,dg为密码,orcl为数据库)
注意: 对于SQLPlus,在输入SQL命令后,记得使用commit提交命令。 当切换用户时,可使用disc/disconn/disconnect断开该用户的连接。 当结束使用SQLPlus时,也可使用exit或quit退出。 三、Oracle连接数的查询与修改查询数据库当前进程的连接数:
select count(*) from v$process;
查询数据库当前会话的连接数: select count(*) from v$session;
查询数据库的并发连接数: select count(*) from v$session where status='ACTIVE';
查询数据库建立的会话情况: select sid,serial#,username,program,machine,status from v$session;
查询数据库允许的最大连接数: select value from v$parameter where name = 'processes'; 或者: show parameter processes;
修改数据库允许的最大连接数: alter system set processes = 300 scope = spfile;(需要重启数据库才能实现连接数的修改)
重启数据库: shutdown immediate;
四、部分Oracle常用命令(部分常用命令参考https://www.cnblogs.com/justdoitba/p/8367271.html)show和set命令是两条用于维护SQL*Plus系统变量的命令 show all --查看所有68个系统变量值 show user --显示当前连接用户 show error --显示错误 set heading off --禁止输出列标题,默认值为ON set feedback off --禁止显示最后一行的计数反馈信息,默认值为"对6个或更多的记录,回送ON" set timing on --默认为OFF,设置查询耗时,可用来估计SQL语句的执行时间,测试性能 set sqlprompt "SQL> " --设置默认提示符,默认值就是"SQL> " set linesize 1000 --设置屏幕显示行宽,默认100 set pagesize 20 --设置每页显示行目数,默认14 set autocommit ON --设置是否自动提交,默认为OFF set pause on --默认为OFF,设置暂停,会使屏幕显示停止,等待按下ENTER键,再显示下一页 set arraysize 1 --默认为15 set long 1000 --默认为80
说明:
set heading off --禁止输出列标题 set feedback off --禁止显示最后一行的计数反馈信息 列出当前用户下所有同义词的定义,可用来测试同义词的真实存在性 select 'desc '||tname from tab where tabtype='SYNONYM'; 查询当前用户下所有表的记录数 select 'select '''||tname||''',count(*) from '||tname||';' from tab where tabtype='TABLE'; 把所有符合条件的表的select权限授予为public select 'grant select on '||table_name||' to public;' from user_tables where 《条件》; 删除用户下各种对象 select 'drop '||tabtype||' '||tname from tab; 删除符合条件用户 select 'drop user '||username||' cascade;' from all_users where user_id>25; 快速编译所有视图
@@文件名 在.sql文件中调用令一个.sql文件时使用 save 文件名 将缓冲区的命令以文件方式存盘,缺省文件扩展名为.sql get 文件名 调入存盘的sql文件 start 文件名 运行调入内存的sql文件 spool 文件名 把这之后的各种操作及执行结果"假脱机"即存盘到磁盘文件上,默认文件扩展名为.lst spool 显示当前的"假脱机"状态 spool off 停止输出 例: exit 退出SQL*PLUS desc 表名 显示表的结构 show user 显示当前连接用户 show error 显示错误 show all 显示所有68个系统变量值 edit 打开默认编辑器,Windows系统中默认是notepad.exe,把缓冲区中最后一条SQL语句调入afiedt.buf文件中进行编辑 edit 文件名 把当前目录中指定的.sql文件调入编辑器进行编辑 clear screen 清空当前屏幕显示 说明:start、edit、spool用法 1.start和@ sql>@ d:\a.sql或是sql>start d:\a.sql 2.edit
sql>edit d:\a.sql,这样会把d:\a.sql 这个文件打开
3.spool sql>spool d:\b.sql并输入sql>spool off 举例: sql>spool d:\b.sql; sql>select * from emp; sql>spool off;
二.Oracle sqlplus语句编辑命令 首先我们输入这样一条指令:
对于SQL命令,有些特殊的符号涉及到SQL语句的执行,无法输入,就要注意 插入特殊字符: 方法1:设置define SQL> set define off SQL> select * from dba_tables where table_name ='&123'; no rows selected SQL> set define on SQL> select * from dba_tables where table_name ='&123'; Enter value for 123: 方法2: select chr(ascii('&')) from dual;
|
|