인프라 7기/Oracle
Oracle 실습 : Quota와 User
킹버거
2023. 3. 17. 13:45
SQL> SELECT u.username, u.default_tablespace, max_bytes, max_blocks
2> FROM dba_users u, dba_ts_quotas q
3> WHERE u.username = q.username
4> AND u.default_tablespace = q.tablespace_name;
- 사용자의 DEFAULT TABLESPACE 별 quota량을 조회한다.
SQL> ALTER USER <user명>
2> QUOTA <크기> ON <tablespace명>;
- User의 quota 량을 조정한다.
SELECT username, tablespace_name, max_bytes, max_blocks FROM dba_ts_quotas
WHERE lower(username) IN ('te', 'st0', 'st1', 'st2')
ORDER BY 1;
* 확인 결과 st0은 quota가 없다. dba_ts_quotas는 quota가 설정된 user만 표시된다.
SELECT u.username, u.default_tablespace, max_bytes, max_blocks
FROM dba_users u, dba_ts_quotas q
WHERE u.username = q.username
AND u.default_tablespace = q.tablespace_name
AND lower(u.username) IN ('te', 'st0', 'st1', 'st2');
* 각 User의 DEFAULT TABLESPACE 별 quota량 -1은 제한하지 않는다는 의미이다.
CONN te/te
CREATE TABLE te (no NUMBER);
SELECT table_name, tablespace_name FROM user_tables;
CONN st0/st0
CREATE TABLE st0 (no NUMBER);
* st0에게는 table을 생성할 수 있는 권한이 없다.
CONN / AS sysdba
SELECT grantee, privilege FROM dba_sys_privs
WHERE grantee = 'ST0';
GRANT create table TO st0;
SELECT grantee, privilege FROM dba_sys_privs
WHERE grantee = 'ST0';
CONN st0/st0
CREATE TABLE st0 (no NUMBER);
INSERT INTO st0 VALUES (1);
CONN / AS sysdba
SELECT username, default_tablespace FROM dba_users
WHERE username = 'ST0';
ALTER USER st0
QUOTA UNLIMITED ON st;
SELECT username, tablespace_name, max_bytes, max_blocks
FROM dba_ts_quotas
WHERE username = 'ST0';
CONN st0/st0
INSERT INTO st0 VALUES (1);