假设有一张学生桌
学生(身份证号,姓名,城市)
我想创建一个用户 A 并仅授予更新 id=10 的记录的权限。
CREATE USER A ;
GRANT UPDATE ON student TO A WHERE student.id=10;
我尝试过这个,但它不起作用。
不,不是一行但是包含一行的视图将依次更新实际的真实表。
这可以通过每个学生的特定表视图来完成(是的,这将是一个混乱的数据库结构)。授予该用户对该视图的访问权限,仅允许选择/更新,并且主键将不可更新。当视图更新时,主表也会自行更新。
CREATE SCHEMA `example` ;
CREATE TABLE `example`.`student` (
`id` INT NOT NULL,
`name` VARCHAR(45) NULL,
`email` VARCHAR(45) NULL,
PRIMARY KEY (`id`));
INSERT INTO `example`.`student` (`id`, `name`, `email`) VALUES ('1', 'bob', '[email protected]');
USE `example`;
CREATE
OR REPLACE SQL SECURITY DEFINER
VIEW `student_1` AS
SELECT
`student`.`id` AS `id`,
`student`.`name` AS `name`,
`student`.`email` AS `email`
FROM
`student`
WHERE
(`student`.`id` = '1');
CREATE USER 'student_1_user'@'localhost' IDENTIFIED BY 'user_password';
GRANT SELECT,UPDATE ON example.student_1 TO student_1_user@localhost IDENTIFIED BY 'user_password';
UPDATE example.student_1 SET email='[email protected]'; // note no primary key needed or allowed
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)