저장 프로시저에서 권한을 찾기 위한 오라클 쿼리
사용자가 저장 프로시저를 실행할 수 있는 권한이 있는지 확인하기 위해 실행할 수 있는 쿼리는 무엇입니까?
사용자가UserA
저장 프로시저 이름은my_stored_proc
나는 알고 싶습니다.UserA
에 대한 실행 권한이 있습니다.my_stored_proc
사용자 A는 저장된 proc의 소유자가 아닙니다.어떤 다른 주인이 그에게 허락을 합니다.
역할을 통해 보조금을 계산하는 방법
select grantee, table_name, privilege
from dba_tab_privs
where
table_name = 'my_stored_proc'
and
owner = 'ownerOfObject'
and
(grantee = 'userA'
or
grantee in
(select granted_role
from dba_role_privs
where grantee = 'userA'
)
)
시도해 볼 수 있습니다.
select ap.*
from All_Procedures ap
where ap.owner = 'UserA'
이것은 사용자 A가 소유자인지 여부만 알려줍니다.나는 A 사용자가 소유자가 아니더라도 여전히 권한을 가질 수 있다고 생각합니다.그것을 어떻게 확인해야 할지 모르겠습니다.
편집: 확인할 다른 표는
USER_SYS_PRIVLS사용자_Tab_PRIVLSUSER_ROLE_PRIVLSROLE_SYS_PRIVLS역할_Tab_PRIVLS
저는 이것들을 거의 조회하지 않았기 때문에 당신이 찾고 있는 것을 찾는 방법을 정확히 알지 못하지만, 이것들부터 시작하겠습니다.
알았어요...
SELECT * FROM DBA_TAB_PRIVS A WHERE GRANTEE = 'UserA' AND GRANTOR = 'someoneelse' and privilege = 'EXECUTE'
이것이 바로 제게 도움이 되었습니다. 제가 액세스할 수 있는 모든 SP를 찾고 싶었습니다.
USER_에서 *를 선택합니다.TAB_PRIVES 여기서 GRANTEE='____' 및 PRIVITY='EXECUTE'
USER_의 열TAB_PRIVES에는 GRANTEE, OWNER, GRANTOR, TABLE_NAME(이 경우 SP 이름) 및 PRIVITY가 포함되어 있으므로 이것이 완벽하다고 생각합니다.
DBA_* 테이블에 액세스할 수 없기 때문에 일반 사용자에게는 dpbradley 및 Omnipresent의 답변이 작동하지 않을 것으로 알고 있습니다.
언급URL : https://stackoverflow.com/questions/2156775/oracle-query-to-find-priveleges-on-a-stored-procedure
'itsource' 카테고리의 다른 글
"display:none"이 이미지 로드를 방해합니까? (0) | 2023.07.31 |
---|---|
NSA ray를 NSData로 변환하는 방법은 무엇입니까? (0) | 2023.07.31 |
Cordova 명령줄 인터페이스를 사용하여 서명된 APK 파일을 만드는 방법은 무엇입니까? (0) | 2023.07.31 |
파이썬의 배열 필터? (0) | 2023.07.26 |
문자열을 분할하여 변수에 할당하는 방법 (0) | 2023.07.26 |