1、SQL编写
-- 新建用户
create user root IDENTIFIED by 123456;
-- 将默认的USERS空间分配给用户
alter user root default tablespace users;
-- 授权角色以及权限(默认三个角色:connect、resource、dba)
grant create session,create table,unlimited tablespace,resource,connect to root;
create session:登录权限
create table:建表权限
unlimited tablespace:用户在自己的空间中不限制大小
resource:resource角色
connect:connect角色
注意:序列名称、触发器名称、表名、字段名等都得带引号,否则会自动被Orale转化成大写,因为Oracle大小写敏感会导致找不到。
-- 创建表
CREATE TABLE "ROOT"."T_STU" (
"id" NUMBER NOT NULL,
"name" VARCHAR2(255),
PRIMARY KEY ("id")
)
-- 创建序列
CREATE SEQUENCE "ROOT"."Seq01" MINVALUE 1 INCREMENT BY 1 NoMaxValue START WITH 1;
-- 创建触发器
create or replace TRIGGER "ROOT"."Trigger01" BEFORE INSERT ON "ROOT"."T_STU" REFERENCING OLD AS "OLD" NEW AS "NEW" FOR EACH ROW
BEGIN
select "Seq01".nextval into :NEW."id" from dual;
END;
-- 插入数据
INSERT INTO "ROOT"."T_STU" ("name") VALUES ('小红');
-- 查看结果
SELECT * FROM ROOT."T_STU";
2、Navicat操作
序列和触发器的位置在【其他】选项里面。
1、创建表:保存时命名 T_STU
示例字段只需要一个id,一个name即可
2、序列-创建序列:保存时命名 Seq001
3、触发器-创建触发器:保存时命名 Trigger001
常规选项卡中:触发器类型选【TABLE】,表模式选【ROOT】,表明选择【T_STU】
高级选项卡中选填:引用旧【OLD】,引用新的【NEW】
定义选项卡中:需要将序列Seq001的序号查出来并放入T_STU表的id中。
BEGIN
select "Seq001".nextval into :NEW."id" from dual;
END;
4、最后看一下预览SQL
其中"Untitled"是未保存的默认触发器名。
5、最后一步插入数据观察递增情况
----------------------------------------------------------------------------------------------------------------------------
其他权限相关操作
-- 创建表空间
create tablespace root_tablespace datafile 'd:\data.dbf' size 2048m;
-- 用户root在表空间root_tablespace中所分配的空间没有限制
alter user ROOT quota unlimited on root_tablespace;
-- 删除表空间
drop tablespace root_tablespace including contents cascade constraints;
-- 查看所有用户
select * from dba_users;
-- 修改密码
alter user root identified by "123456";
-- revoke取消授权
revoke resource from root;
-- 查看角色包含的权限
select * from role_sys_privs where ROLE='CONNECT' or ROLE='RESOURCE';
-- 查看用户拥有的角色
select * from dba_role_privs where GRANTEE='ROOT';
-- 查看用户拥有的系统权限
select * from dba_sys_privs where GRANTEE='ROOT';