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

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...