oracle在原有数据库上创建用户并赋予权限表空间等需要赋予的信息

oracle在原有数据库上创建用户并赋予权限表空间等需要赋予的信息,第1张

create user draft indentified by draft default tablespace tablespacename temporary tablespace temp;

alter user draft account unlock;

上面是建用后语句,“tablespacename”是指这个用后的默认表空间,以后这个用户建表等如果不指定表空间就默认建在这个表空间上,赋权语句如下:

grant connect to draft;

grant resource to draft;

connect权限是必须的,如果没有connect权限该用后无法连接数据库。

1> -- 通过将 test_user 加入数据库角色 db_owner

2> exec sp_addrolemember 'db_owner', 'test_user'

3> go

grant 权限 on 数据库对象 to 用户

一、grant 普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利。

grant select on testdb to common_user@’%’

grant insert on testdb to common_user@’%’

grant update on testdb to common_user@’%’

grant delete on testdb to common_user@'%'

或者

grant select, insert, update, delete on testdb to common_user@’%’

二、grant 数据库开发人员,创建表、索引、视图、存储过程、函数。。。等权限。

grant 创建、修改、删除 MySQL 数据表结构权限。

grant create on testdb to developer@’1921680%’;

grant alter on testdb to developer@’1921680%’;

grant drop on testdb to developer@’1921680%’;

grant *** 作 MySQL 外键权限。

grant references on testdb to developer@’1921680%’;

grant *** 作 MySQL 临时表权限。

grant create temporary tables on testdb to developer@’1921680%’;

grant *** 作 MySQL 索引权限。

grant index on testdb to developer@’1921680%’;

grant *** 作 MySQL 视图、查看视图源代码 权限。

grant create view on testdb to developer@’1921680%’;

grant show view on testdb to developer@’1921680%’;

grant *** 作 MySQL 存储过程、函数 权限。

grant create routine on testdb to developer@’1921680%’; — now, can show procedure status

grant alter routine on testdb to developer@’1921680%’; — now, you can drop a procedure

grant execute on testdb to developer@’1921680%’;

三、grant 普通 DBA 管理某个 MySQL 数据库的权限。

grant all privileges on testdb to dba@’localhost’

其中,关键字 “privileges” 可以省略。

四、grant 高级 DBA 管理 MySQL 中所有数据库的权限。

grant all on to dba@’localhost’

五、MySQL grant 权限,分别可以作用在多个层次上。

1 grant 作用在整个 MySQL 服务器上:

grant select on to dba@localhost; — dba 可以查询 MySQL 中所有数据库中的表。

grant all on to dba@localhost; — dba 可以管理 MySQL 中的所有数据库

2 grant 作用在单个数据库上:

grant select on testdb to dba@localhost; — dba 可以查询 testdb 中的表。

3 grant 作用在单个数据表上:

grant select, insert, update, delete on testdborders to dba@localhost;

这里在给一个用户授权多张表时,可以多次执行以上语句。例如:

grant select(user_id,username) on smpusers to mo_user@’%’ identified by ‘123345′;

grant select on smpmo_sms to mo_user@’%’ identified by ‘123345′;

4 grant 作用在表中的列上:

grant select(id, se, rank) on testdbapache_log to dba@localhost;

5 grant 作用在存储过程、函数上:

grant execute on procedure testdbpr_add to ‘dba’@'localhost’

grant execute on function testdbfn_add to ‘dba’@'localhost’

六、查看 MySQL 用户权限

查看当前用户(自己)权限:

show grants;

查看其他 MySQL 用户权限:

show grants for zhangkh@localhost;

七、撤销已经赋予给 MySQL 用户权限的权限。

revoke 跟 grant 的语法差不多,只需要把关键字 “to” 换成 “from” 即可:

grant all on to dba@localhost;

revoke all on from dba@localhost;

八、MySQL grant、revoke 用户权限注意事项

1 grant, revoke 用户权限后,该用户只有重新连接 MySQL 数据库,权限才能生效。

2 如果想让授权的用户,也可以将这些权限 grant 给其他用户,需要选项 “grant option“

grant select on testdb to dba@localhost with grant option;

这个特性一般用不到。实际中,数据库权限最好由 DBA 来统一管理。

mysql授权表共有5个表:user、db、host、tables_priv和columns_priv。

授权表的内容有如下用途:

user表

user表列出可以连接服务器的用户及其口令,并且它指定他们有哪种全局(超级用户)权限。在user表启用的任何权限均是全局权限,并适用于所有数据库。例如,如果你启用了DELETE权限,在这里列出的用户可以从任何表中删除记录,所以在你这样做之前要认真考虑。

db表

db表列出数据库,而用户有权限访问它们。在这里指定的权限适用于一个数据库中的所有表。

host表

host表与db表结合使用在一个较好层次上控制特定主机对数据库的访问权限,这可能比单独使用db好些。这个表不受GRANT和REVOKE语句的影响,所以,你可能发觉你根本不是用它。

tables_priv表

tables_priv表指定表级权限,在这里指定的一个权限适用于一个表的所有列。

columns_priv表

columns_priv表指定列级权限。这里指定的权限适用于一个表的特定列。

注:

对于GRANT USAGE ON,查看手册有如下介绍和实例:

mysql> GRANT USAGE ON TO ‘zhangkh’@'localhost’;

一个账户有用户名zhangkh,没有密码。该账户只用于从本机连接。未授予权限。通过GRANT语句中的USAGE权限,你可以创建账户而不授予任何权限。它可以将所有全局权限设为’N'。假定你将在以后将具体权限授予该账户。

oracle可以通过设置表的权限来设定用户对表的访问权限。

通过dba权限用户或者表的拥有者用户来设定相关权限。

基本的权限主要有三个,select,update和delete

其实还有一个alter权限,不过这个权限不建议授予,这个还是掌握在dba手中比较好。不然将来会很麻烦。

授权语句大同小异,只是dba授权的话,需要加上表的所属用户。

举例:比如要把aaa用户下的a表,授予bbb用户。dba用户为ccc

那么用aaa用户的授权语句为

grant select on a to bbb;

使用ccc用户的授权语句为

grant select on aaaa to bbb;

其他的update,和delete只要把select 替换就好。

当然如果三个权限都想授予。那么可以考虑grant all on a to bbb;

下面的例子显示如何使用MySQL客户安装新用户 这些例子假定权限已缺省被安装 这意味着为了改变 你必须在MySQL正在运行同一台机器上 你必须作为MySQL root用户连接 并且root用户必须对MySQL数据库有insert权限和reload管理权限 另外 如果你改变了root用户口令 你必须如下的MySQL命令指定它

你可以通过发出GRANT语句增加新用户

shell> mysql user=root mysql mysql> GRANT ALL PRIVILEGES ON TO monty@localhost IDENTIFIED BY something WITH GRANT OPTION; mysql> GRANT ALL PRIVILEGES ON TO monty@ % IDENTIFIED BY something WITH GRANT OPTION; mysql> GRANT RELOAD PROCESS ON TO admin@localhost; mysql> GRANT USAGE ON TO dummy@localhost;

这些GRANT语句安装 个新用户

monty 可以从任何地方连接服务器的一个完全的超级用户 但是必须使用一个口令( something 做这个 注意 我们必须对 monty@localhost和monty@ % 发出GRANT语句 如果我们增加localhost条目 对localhost的匿名用户条目在我 们从本地主机连接接时由mysql_install_db创建的条目将优先考虑 因为它有更特定的Host字段值 所以以user表排列顺序看更早到来

admin 可以从localhost没有一个口令进行连接并且被授予reload和process管理权限的用户 这允许用户执行mysqladmin reload mysqladmin refresh和mysqladmin flush 命令 还有mysqladmin processlist 没有授予数据库有关的权限 他们能在以后通过发出另一个GRANT语句授权

dummy 可以不用一个口令连接的一个用户 但是只能从本地主机 全局权限被设置为 N USAGE权限类型允许你无需权限就可设置一个用户 它假定你将在以后授予数据库相关的权限

你也可以直接通过发出INSERT语句增加同样的用户存取信息 然后告诉服务器再次装入授权表

shell> mysql user=root mysql mysql> INSERT INTO user VALUES( localhost monty PASSWORD( something ) Y Y Y Y Y Y Y Y Y Y Y Y Y Y ) mysql> INSERT INTO user VALUES( % monty PASSWORD( something ) Y Y Y Y Y Y Y Y Y Y Y Y Y Y ) mysql> INSERT INTO user SET Host= localhost User= admin Reload_priv= Y Process_priv= Y ; mysql> INSERT INTO user (Host User Password) VALUES( localhost dummy ); mysql> FLUSH PRIVILEGES;

取决于你的MySQL版本 对上述 你可能必须使用一个不同数目 Y 值(在 以前的版本有更少的权限列) 对admin用户 只用在 开始的版本具有的更加可读的INSERT扩充的语法

注意 为了设置一个超级用户 你只需创造一个user表条目 其权限字段设为 Y 不需要db或host表的条目

在user表中的权限列不是由最后一个INSERT语句明确设置的(对dummy用户) 因此那些列被赋予缺省值 N 这是GRANT USAGE做的同样的事情

下列例子增加一个用户custom 他能从主机localhost server domain和whitehouse gov连接 他只想要从 localhost存取bankaccount数据库 从whitehouse gov存取expenses数据库和从所有 台主机存取customer 数据库 他想要从所有 台主机上使用口令stupid

为了使用GRANT语句设置个用户的权限 运行这些命令

shell> mysql user=root mysql mysql> GRANT SELECT INSERT UPDATE DELETE CREATE DROP ON bankaccount TO custom@localhost IDENTIFIED BY stupid ; mysql> GRANT SELECT INSERT UPDATE DELETE CREATE DROP ON expenses TO custom@whitehouse gov IDENTIFIED BY stupid ; mysql> GRANT SELECT INSERT UPDATE DELETE CREATE DROP ON customer TO custom@ % IDENTIFIED BY stupid ;

通过直接修改授权表设置用户权限 运行这些命令(注意 在结束时FLUSH PRIVILEGES)

lishixinzhi/Article/program/MySQL/201311/29628

以上就是关于oracle在原有数据库上创建用户并赋予权限表空间等需要赋予的信息全部的内容,包括:oracle在原有数据库上创建用户并赋予权限表空间等需要赋予的信息、用SQL语句如何赋予sql登陆帐号dbowner的权限 注意是SQL语句 企业管理器的别来了、mysql grant 哪些权限等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10153201.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存