ORACLE多表查询保存到新表,添加id自增触发器

2023-12-22 13:48

本文主要是介绍ORACLE多表查询保存到新表,添加id自增触发器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先把需求明确一下,这次需要从其他两个表(T1,T2)中查询数据将其中两个字段相同的数据插入到另一张表中(T3),T3的id为主键不能为空

由于使用的是oracle,不能把T3的id设置成自增长就多出许多麻烦

为了解决oracle序列自增长的问题  采用了触发器触发序列自增长的方式来解决


1.首先创建一条自增长的序列,开始于1,每次增长1

CREATE SEQUENCE TOOLS_GRP_ID START WITH 1 INCREMENT BY 1;

2.其次创建触发器,每次插入数据时都自动的引用序列的id进行添加

CREATE

OR REPLACE TRIGGER TOOLS_GRP BEFORE INSERT ON MES_PRODUCE_TOOLS_GRP_DETAIL FOR EACH ROW

BEGIN

    SELECT

        TOOLS_GRP_ID.nextval INTO : NEW . ID

    FROM

        dual ;

    END ;


其中INTO : NEW . ID,NEW. 之后的为需要自增长的列名 ,

TOOLS_GRP:触发器名称,MES_PRODUCE_TOOLS_GRP_DETAIL:触发器监听对象,

TOOLS_GRP_ID:序列名称   dual虚拟表是oracle数据库常用的虚拟表只有一条记录,没有实际意义


在编写触发器的过程中遇到了[Err] ORA-24344: 成功, 但出现编译错误

在查阅网上相关资料之后,并没有实际解决 ,但修改列名后不知道怎么的就有用了,总结有以下可能性

(1)网上有一种可能是数据库列名大小写问题,

解决方法应该所有列名都为大写

(2)我自己的情况是列名本来都是全大写的,不存在上一条的情况。

解决方法首先把表中的ID改为PID防止oracle无法识别,其次,在重新打了一次INTO : NEW . ID 之后编译成功。


3.查询T1,T2表格中的数据插入T3,自动触发触发器TOOLS_GRP 

INSERT INTO MES_PRODUCE_TOOLS_GRP_DETAIL (TOOLS_GRP_ID, TOOLS_ID) SELECT
        TOOLS_GRP_ID,
        TOOLS_ID
    FROM
        MES_PRODUCE_TOOLS_GRP,
        MES_PRODUCE_TOOLS
    WHERE
        MES_PRODUCE_TOOLS_GRP.TOOLS_GRP_NAME = MES_PRODUCE_TOOLS.JSON


完成需求大笑

这篇关于ORACLE多表查询保存到新表,添加id自增触发器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/524185

相关文章

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满