Oracle数据表ID自增操作

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';

猜你喜欢

转载自blog.csdn.net/JohnGene/article/details/128220263
今日推荐