oracle01031,oracle01033
ORA-01031权限不足
法1)可视化授权:你登陆的超级管理员用户,找到用户的名字,然后右击编辑用户,在权限栏下找到,create view 这个权限后打上√;保存应用就行了;
法2)DOS命令:输入sqlplus /nolog 回车 conn sys密码@orcl as sysdba 回车 grant create view to scott 回车 输入 ; 授权成功!
oracle 遇到ora-01031
已经提示你了。权限不足。你可以看一下上面是哪一语句报的这个错,然后把对应表,视图,过程的权限授权给当前用户
oracle数据库连接报ora-01031怎么解决?
权限不足,你看下oracle的密码文件是否损坏。如果损坏就重建一下了
oracle ora-01031
在使用sys用户使用管理员登陆的时候,出现ORA-01031解决办法
1 首先使用本地系统用户启动数据库,使用名称查看配置参数
show parameter password
查看参数状态EXCLUSIVE则为正常状态,如果不是,则修改pfile或者是spfile的参数
alter system set remote_login_passwordfile='EXCLUSIVE'
2 查询密码文件视图
select * from v$pwfile_users
如果没有结果集返回,则说明密码文件有问题,重新配置密码文件并且给用户赋予sysdba权限
使用命令 orapwd file=orapworcl password=root entries=10
创建密码文件,
grant sysdba to system
给system用户赋予dba权限
再次查询,应该有 sys,system两个用户具有sysdba权限
3 如果select * from v$pwfile_users 可以准确返回sys 用户,在本地系统也可以使用密码文件登录,但是不能远程使用sys账号启动数据库,报ORA-01031错误。那么很有可能是监听文件配置有问题,修改监听文件。(下面给一个正确的模板)
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = orcl)
(ORACLE_HOME = /u01/app/oracle)
(SID_NAME = orcl)
)
)
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST =192.168.1.3)(PORT = 1521))
)
)
ora-01031:insufficient privileges ora-01031:insufficient privileges
sqlplus "/ as sysdba" 连不上,报ora-01031:insufficient privileges解决方法
注意多个数据库实例时候,set ORACLE_SID='',
1、检查sqlnet.ora(WINDOWS下位于%ORACLE_HOME%NETWORKADMIN目录)是否包含这句:SQLNET.AUTHENTICATION_SERVICES=(NTS),没有的话加上
2、检查登陆windows的用户(administrator或安装oracle时候使用的用户)是不是在包含在ORA_DBA组中,域用户没有连上域服务器时就可能出现这种现象。
3. 要保证 remote_login_passwordfile 参数 = EXCLUSIVE .
4. 看看是否需要使用orapassw生成口令文件 .
一种解决方法案例:
1、检查系统参数:SQL show parameter password
NAME TYPE VALUE------------------------------------ ----------- ------------------------------
remote_login_passwordfile string EXCLUSIVE
2、
select * from v$pwfile_users;
SQL
为空
3、SQL grant sysdba to sys;
grant sysdba to sys
*
ERROR at line 1:
ORA-01994: GRANT failed: password file missing or disabled
4、建立password文件
D:/orapwd file="D:/oracle/product/10g/db_1/database/PWDoratest.ora" password=gp
oswong entries=10
5、
SQL select * from v$pwfile_users;
USERNAME SYSDB SYSOP------------------------------ ----- -----
SYS TRUE TRUE
SYS正常显示出来。
6、重新在远程以SYSDBA登录,可正常使用。
如果口令文件创建的有问题,也是会报如下的错误:
ora-01031:insufficient privileges
口令文件的命名格式应为orapwsid,并且sid是区分大小写的。由于Target Database连接Auxiliary Database时需要验证口令,如果违反了以上规则,将会提示ORA-01031: insufficient privileges。
我在用linux创建duplicate数据库的时候 就是因为口令文件创建的路径和名称不对才遇到这个错误
-----end-------
oracle查询视图报错ORA-01031: insufficient privileges
将建有该视图的用户,作如下处理就可以解决该问题:
将该视图中涉及的物理表做权限分配,记得一定要加上with grant option选项即可
如:grant select on 表名 to 拥有该视图的用户 with grant option