Oracle数据表ID自增操作
创始人
2024-03-24 03:59:00
0

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

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...