How can to make a new user see table in existing schema
Clash Royale CLAN TAG#URR8PPP
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty margin-bottom:0;
up vote
2
down vote
favorite
I'm new into Oracle so this question might be dumb. I created new user and now I would like him to see table (or even better all tables by one command) in already existing schema (hr schema in this case). Is it even possible?
From my understanding databases store data and Schemas are equal to Users, so can two users see the same data stored in database, like in my case?
oracle oracle-11g-r2 permissions schema users
New contributor
add a comment |Â
up vote
2
down vote
favorite
I'm new into Oracle so this question might be dumb. I created new user and now I would like him to see table (or even better all tables by one command) in already existing schema (hr schema in this case). Is it even possible?
From my understanding databases store data and Schemas are equal to Users, so can two users see the same data stored in database, like in my case?
oracle oracle-11g-r2 permissions schema users
New contributor
add a comment |Â
up vote
2
down vote
favorite
up vote
2
down vote
favorite
I'm new into Oracle so this question might be dumb. I created new user and now I would like him to see table (or even better all tables by one command) in already existing schema (hr schema in this case). Is it even possible?
From my understanding databases store data and Schemas are equal to Users, so can two users see the same data stored in database, like in my case?
oracle oracle-11g-r2 permissions schema users
New contributor
I'm new into Oracle so this question might be dumb. I created new user and now I would like him to see table (or even better all tables by one command) in already existing schema (hr schema in this case). Is it even possible?
From my understanding databases store data and Schemas are equal to Users, so can two users see the same data stored in database, like in my case?
oracle oracle-11g-r2 permissions schema users
oracle oracle-11g-r2 permissions schema users
New contributor
New contributor
New contributor
asked 1 hour ago
Rocket128
111
111
New contributor
New contributor
add a comment |Â
add a comment |Â
2 Answers
2
active
oldest
votes
up vote
1
down vote
Log in as HR user and run following statement (first replacing the OTHER_USER with actual username):
select 'GRANT SELECT ON ' || table_name || ' TO OTHER_USER;' from user_tables;
then copy the output, paste and execute it as HR user.
New contributor
Is there some sqlplus command equivalent to this statement?
â Rocket128
1 hour ago
add a comment |Â
up vote
1
down vote
It is something Oracle could have solved ages ago. There is no simple command do it, so usually we just loop through the tables and grant object level privileges:
set serveroutput on
declare
l_cmd clob;
begin
for t in (select * from all_tables where owner = 'HR')
loop
begin
l_cmd := 'grant select on "' || t.owner || '"."' || t.table_name || '" to new_user';
execute immediate l_cmd;
exception when others then dbms_output.put_line(l_cmd);
end;
end loop;
end;
/
Tables created after this in HR schema will not be visible to the other user, each time an object is created, the privileges should be granted on that.
A better solution is to create a role, lets say HR_READONLY
, and each time a new table is created in HR schema, the privileges on that object should be granted to HR_READONLY
. Then you can just simply grant this role to the other user. This requires some self discipline from the developers, but I have seen some of them follow this method.
Is there some sqlplus command equivalent to this statement? When I log as hr user and try this command it's not working: grant select on jobs to TestUser;
â Rocket128
1 hour ago
@Rocket128 - no. But theDatabase Idea
isUnder Review - Voting still open
. See: community.oracle.com/ideas/2333 (requires registration to Vote)
â Michael Kutz
17 mins ago
add a comment |Â
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
1
down vote
Log in as HR user and run following statement (first replacing the OTHER_USER with actual username):
select 'GRANT SELECT ON ' || table_name || ' TO OTHER_USER;' from user_tables;
then copy the output, paste and execute it as HR user.
New contributor
Is there some sqlplus command equivalent to this statement?
â Rocket128
1 hour ago
add a comment |Â
up vote
1
down vote
Log in as HR user and run following statement (first replacing the OTHER_USER with actual username):
select 'GRANT SELECT ON ' || table_name || ' TO OTHER_USER;' from user_tables;
then copy the output, paste and execute it as HR user.
New contributor
Is there some sqlplus command equivalent to this statement?
â Rocket128
1 hour ago
add a comment |Â
up vote
1
down vote
up vote
1
down vote
Log in as HR user and run following statement (first replacing the OTHER_USER with actual username):
select 'GRANT SELECT ON ' || table_name || ' TO OTHER_USER;' from user_tables;
then copy the output, paste and execute it as HR user.
New contributor
Log in as HR user and run following statement (first replacing the OTHER_USER with actual username):
select 'GRANT SELECT ON ' || table_name || ' TO OTHER_USER;' from user_tables;
then copy the output, paste and execute it as HR user.
New contributor
New contributor
answered 1 hour ago
Michal
111
111
New contributor
New contributor
Is there some sqlplus command equivalent to this statement?
â Rocket128
1 hour ago
add a comment |Â
Is there some sqlplus command equivalent to this statement?
â Rocket128
1 hour ago
Is there some sqlplus command equivalent to this statement?
â Rocket128
1 hour ago
Is there some sqlplus command equivalent to this statement?
â Rocket128
1 hour ago
add a comment |Â
up vote
1
down vote
It is something Oracle could have solved ages ago. There is no simple command do it, so usually we just loop through the tables and grant object level privileges:
set serveroutput on
declare
l_cmd clob;
begin
for t in (select * from all_tables where owner = 'HR')
loop
begin
l_cmd := 'grant select on "' || t.owner || '"."' || t.table_name || '" to new_user';
execute immediate l_cmd;
exception when others then dbms_output.put_line(l_cmd);
end;
end loop;
end;
/
Tables created after this in HR schema will not be visible to the other user, each time an object is created, the privileges should be granted on that.
A better solution is to create a role, lets say HR_READONLY
, and each time a new table is created in HR schema, the privileges on that object should be granted to HR_READONLY
. Then you can just simply grant this role to the other user. This requires some self discipline from the developers, but I have seen some of them follow this method.
Is there some sqlplus command equivalent to this statement? When I log as hr user and try this command it's not working: grant select on jobs to TestUser;
â Rocket128
1 hour ago
@Rocket128 - no. But theDatabase Idea
isUnder Review - Voting still open
. See: community.oracle.com/ideas/2333 (requires registration to Vote)
â Michael Kutz
17 mins ago
add a comment |Â
up vote
1
down vote
It is something Oracle could have solved ages ago. There is no simple command do it, so usually we just loop through the tables and grant object level privileges:
set serveroutput on
declare
l_cmd clob;
begin
for t in (select * from all_tables where owner = 'HR')
loop
begin
l_cmd := 'grant select on "' || t.owner || '"."' || t.table_name || '" to new_user';
execute immediate l_cmd;
exception when others then dbms_output.put_line(l_cmd);
end;
end loop;
end;
/
Tables created after this in HR schema will not be visible to the other user, each time an object is created, the privileges should be granted on that.
A better solution is to create a role, lets say HR_READONLY
, and each time a new table is created in HR schema, the privileges on that object should be granted to HR_READONLY
. Then you can just simply grant this role to the other user. This requires some self discipline from the developers, but I have seen some of them follow this method.
Is there some sqlplus command equivalent to this statement? When I log as hr user and try this command it's not working: grant select on jobs to TestUser;
â Rocket128
1 hour ago
@Rocket128 - no. But theDatabase Idea
isUnder Review - Voting still open
. See: community.oracle.com/ideas/2333 (requires registration to Vote)
â Michael Kutz
17 mins ago
add a comment |Â
up vote
1
down vote
up vote
1
down vote
It is something Oracle could have solved ages ago. There is no simple command do it, so usually we just loop through the tables and grant object level privileges:
set serveroutput on
declare
l_cmd clob;
begin
for t in (select * from all_tables where owner = 'HR')
loop
begin
l_cmd := 'grant select on "' || t.owner || '"."' || t.table_name || '" to new_user';
execute immediate l_cmd;
exception when others then dbms_output.put_line(l_cmd);
end;
end loop;
end;
/
Tables created after this in HR schema will not be visible to the other user, each time an object is created, the privileges should be granted on that.
A better solution is to create a role, lets say HR_READONLY
, and each time a new table is created in HR schema, the privileges on that object should be granted to HR_READONLY
. Then you can just simply grant this role to the other user. This requires some self discipline from the developers, but I have seen some of them follow this method.
It is something Oracle could have solved ages ago. There is no simple command do it, so usually we just loop through the tables and grant object level privileges:
set serveroutput on
declare
l_cmd clob;
begin
for t in (select * from all_tables where owner = 'HR')
loop
begin
l_cmd := 'grant select on "' || t.owner || '"."' || t.table_name || '" to new_user';
execute immediate l_cmd;
exception when others then dbms_output.put_line(l_cmd);
end;
end loop;
end;
/
Tables created after this in HR schema will not be visible to the other user, each time an object is created, the privileges should be granted on that.
A better solution is to create a role, lets say HR_READONLY
, and each time a new table is created in HR schema, the privileges on that object should be granted to HR_READONLY
. Then you can just simply grant this role to the other user. This requires some self discipline from the developers, but I have seen some of them follow this method.
answered 1 hour ago
Balazs Papp
23.8k2930
23.8k2930
Is there some sqlplus command equivalent to this statement? When I log as hr user and try this command it's not working: grant select on jobs to TestUser;
â Rocket128
1 hour ago
@Rocket128 - no. But theDatabase Idea
isUnder Review - Voting still open
. See: community.oracle.com/ideas/2333 (requires registration to Vote)
â Michael Kutz
17 mins ago
add a comment |Â
Is there some sqlplus command equivalent to this statement? When I log as hr user and try this command it's not working: grant select on jobs to TestUser;
â Rocket128
1 hour ago
@Rocket128 - no. But theDatabase Idea
isUnder Review - Voting still open
. See: community.oracle.com/ideas/2333 (requires registration to Vote)
â Michael Kutz
17 mins ago
Is there some sqlplus command equivalent to this statement? When I log as hr user and try this command it's not working: grant select on jobs to TestUser;
â Rocket128
1 hour ago
Is there some sqlplus command equivalent to this statement? When I log as hr user and try this command it's not working: grant select on jobs to TestUser;
â Rocket128
1 hour ago
@Rocket128 - no. But the
Database Idea
is Under Review - Voting still open
. See: community.oracle.com/ideas/2333 (requires registration to Vote)â Michael Kutz
17 mins ago
@Rocket128 - no. But the
Database Idea
is Under Review - Voting still open
. See: community.oracle.com/ideas/2333 (requires registration to Vote)â Michael Kutz
17 mins ago
add a comment |Â
Rocket128 is a new contributor. Be nice, and check out our Code of Conduct.
Rocket128 is a new contributor. Be nice, and check out our Code of Conduct.
Rocket128 is a new contributor. Be nice, and check out our Code of Conduct.
Rocket128 is a new contributor. Be nice, and check out our Code of Conduct.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f221645%2fhow-can-to-make-a-new-user-see-table-in-existing-schema%23new-answer', 'question_page');
);
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password