mysql中只给用户授权某个表的update权限,用户能对这个表进行更新操作吗?

  1. 只给用户'xiaocong'@'%'授权update权限

grant update on dbt3.customer to 'xiaocong'@'%';
show grants;
  1. 用xiaocong用户连接数据库,然后队dbt3.customer表进行update操作

2.1先用root用户查询出dbt3.customer表的第一行记录

2.2然后进行update操作

update customer set c_nationkey = 15 where c_custkey = 1;

2.3发现不能进行update操作,提示没有select权限对dbt3.customer表的c_custkey这个字段

  1. 给'xiaocong'@'%'授予select权限再进行操作

 grant select on dbt3.customer to 'xiaocong'@'%';
flush privileges;
show grants for 'xiaocong'@'%';
  1. 再次进行对dbt3.customer表update操作

 update customer set c_nationkey = 15 where c_custkey = 1;

总结:为了执行UPDATE操作,用户还需要具有SELECT权限,以便从表中检索数据以进行更新。如果您只想允许用户执行特定的UPDATE操作,您可以使用WHERE子句限制更新的行。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值