博客
关于我
【2020-2021春学期】数据库作业11:第四章课后题
阅读量:136 次
发布时间:2019-02-27

本文共 1127 字,大约阅读时间需要 3 分钟。

建立两个表,并为六个用户授予相应权限

首先创建以下两个表:

create table staff(Sno char, Sname char, Sage int, Sduty char, Ssalary int, Sdept char);

create table dept(Dno char, Dname char, Dboss char, Daddress char, Dphone char);

创建六个用户:王明、李勇、刘星、张新、周平、杨兰,均为无登录用户。

用户权限分配方案如下:

  • 王明获得两个表的SELECT权限:

    grant select on staff to 王明;
    grant select on dept to 王明;

  • 李勇获得两个表的INSERT和DELETE权限:

    grant insert, delete on staff to 李勇;
    grant insert, delete on dept to 李勇;

  • 每个职工仅对其自身记录拥有SELECT权限:

    grant select on staff when user() = Nameto all;
    grant select on dept when user() = Nameto all;

  • 刘星获得职工表的SELECT和更新(工资字段)权限:

    grant select, update(Ssalary) on staff to 刘星;

  • 张新获得两个表的更新权限:

    grant update on staff to 张新;
    grant update on dept to 张新;

  • 周平获得两个表的全部权限(SELECT、INSERT、UPDATE、DELETE),并可授予其他用户权限:

    grant all on staff to 周平 with grant option;
    grant all on dept to 周平 with grant option;

  • 杨兰获得每个部门的SELECT最高工资、最低工资和平均工资权限,但不得查看个人工资:

    -- 需要先创建视图:
    create view view_salary as
    select staff.Sdept department_number,
    max(staff.Ssalary) highest_salary,
    min(staff.Ssalary) lowest_salary,
    avg(staff.Ssalary) average_salary
    from staff
    group by staff.Sdept;
    grant select on view_salary to 杨兰;

  • 注:聚合函数列名需明确指定。

    转载地址:http://cknb.baihongyu.com/

    你可能感兴趣的文章
    Openlayers Map事件基础及重点内容讲解
    查看>>
    Openlayers Select的用法、属性、方法、事件介绍
    查看>>
    Openlayers Source基础及重点内容讲解
    查看>>
    Openlayers view三要素(zoom,center,projection)及其他参数属性方法介绍
    查看>>
    OpenLayers 入门使用
    查看>>
    Openlayers 入门教程(一):应该如何学习 Openlayers
    查看>>
    openlayers 入门教程(七):Interactions 篇
    查看>>
    openlayers 入门教程(三):view 篇
    查看>>
    openlayers 入门教程(九):overlay 篇
    查看>>
    openlayers 入门教程(二):map 篇
    查看>>
    openlayers 入门教程(五):sources 篇
    查看>>
    openlayers 入门教程(八):Geoms 篇
    查看>>
    openlayers 入门教程(六):controls 篇
    查看>>
    openlayers 入门教程(十一):Formats 篇
    查看>>
    openlayers 入门教程(十三):动画
    查看>>
    openlayers 入门教程(十二):定位与轨迹
    查看>>
    openlayers 入门教程(十五):与 canvas、echart,turf 等交互
    查看>>
    openlayers 入门教程(十四):第三方插件
    查看>>
    openlayers 入门教程(四):layers 篇
    查看>>
    OpenLayers 项目分析(三)-OpenLayers中定制JavaScript内置类
    查看>>