Oracle 数据库中,并行 DML
在 Oracle 数据库中,PL/SQL 的 BEGIN...END 块默认是串行执行的,但可以通过以下方法实现并行处理,提升大规模数据操作的性能:
并行 DML(Data Manipulation Language)
在 BEGIN...END 块中启用并行 DML(如 INSERT、UPDATE、DELETE),需显式配置会话参数和语法提示。
启用并行 DML:
ALTER SESSION ENABLE PARALLEL DML;
使用并行提示:
BEGIN
-- 并行插入(DOP=8)
INSERT /*+ PARALLEL(t 8) */ INTO target_table t
SELECT /*+ PARALLEL(s 8) */ * FROM source_table s;
COMMIT;
END;
/
注意事项:
-
必须显式提交(
COMMIT)才能释放并行资源。 -
监控资源使用(CPU、I/O)避免过载。
并行查询(Parallel Query)
在 SELECT 语句中使用并行提示,加速数据检索(适用于复杂查询或大数据量)。
DECLARE
CURSOR c_emp IS
SELECT /*+ PARALLEL(emp 8) */ employee_id, salary
FROM employees emp
WHERE department_id = 50;
BEGIN
FOR rec IN c_emp LOOP
-- 处理每条记录(例如写入日志)
DBMS_OUTPUT.PUT_LINE(rec.employee_id || ': ' || rec.salary);
END LOOP;
END;
/
并行函数调用(Parallel Pipelined Functions)
CREATE OR REPLACE FUNCTION process_data_parallel
RETURN SYS_REFCURSOR
PARALLEL_ENABLE (PARTITION BY ANY) -- 启用并行
ISv_cursor SYS_REFCURSOR;
BEGINOPEN v_cursor FORSELECT /*+ PARALLEL(emp 8) */ employee_id, salary * 1.1 AS new_salaryFROM employees emp;RETURN v_cursor;
END;
/-- 调用并行函数
DECLAREv_result SYS_REFCURSOR;v_id employees.employee_id%TYPE;v_salary employees.salary%TYPE;
BEGINv_result := process_data_parallel;LOOPFETCH v_result INTO v_id, v_salary;EXIT WHEN v_result%NOTFOUND;-- 处理数据(例如插入新表)INSERT INTO salary_updates VALUES (v_id, v_salary);END LOOP;CLOSE v_result;COMMIT;
END;
/
关键配置与注意事项
(1) 参数配置
parallel_max_servers:控制最大并行进程数。
ALTER SYSTEM SET parallel_max_servers = 64;
parallel_degree_policy:设置并行策略(AUTO、MANUAL、LIMITED)。
ALTER SESSION SET parallel_degree_policy = AUTO;
(2) 资源监控
查看并行进程状态:
SELECT sid, serial#, qcsid, server_group, server_set, degree
FROM v$px_session;
监控并行任务进度:
SELECT * FROM v$session_longops WHERE opname LIKE '%PARALLEL%';
(3) 事务与锁
-
长事务风险:并行操作可能持有更多锁,需分批提交。
-
死锁预防:避免跨并行任务的资源竞争。
性能对比
| 场景 | 方法 | 优势 | 适用数据量 |
|---|---|---|---|
| 批量插入/更新 | 并行 DML + APPEND | 直接路径写入,减少 Redo 日志 | 百万级+ |
| 复杂查询处理 | 并行查询提示 | 加速数据检索 | 十万级+ |
| 分块数据更新 | DBMS_PARALLEL_EXECUTE | 自动分块,负载均衡 | 千万级+ |
| 流式数据处理 | 并行管道函数 | 灵活处理复杂逻辑 | 十万级+ |
相关文章:
Oracle 数据库中,并行 DML
在 Oracle 数据库中,PL/SQL 的 BEGIN...END 块默认是串行执行的,但可以通过以下方法实现并行处理,提升大规模数据操作的性能: 并行 DML(Data Manipulation Language) 在 BEGIN...END 块中启用并行 DML&am…...
Spring Boot 集成 Redis中@Cacheable 和 @CachePut 的详细对比,涵盖功能、执行流程、适用场景、参数配置及代码示例
以下是 Cacheable 和 CachePut 的详细对比,涵盖功能、执行流程、适用场景、参数配置及代码示例: 1. 核心对比表格 特性CacheableCachePut作用缓存方法的返回结果,避免重复计算执行方法并更新缓存,不覆盖原有缓存执行流程缓存命中…...
3500 阶乘求和
3500 阶乘求和 ⭐️难度:中等 🌟考点:2023、思维、省赛 📖 📚 import java.util.Scanner;public class Main {public static void main(String[] args) {long sum 0;for(int i1;i<50;i) { // 之后取模都相等su…...
软件工程(应试版)图形工具总结(二)
遇到的问题,都有解决方案,希望我的博客能为你提供一点帮助。 教材参考《软件工程导论(第六版)》 七、 层次图(H图)与HIPO图 1、概述 1.1、层次图(Hierarchy Chart / H图) 核心…...
思维链、思维树、思维图与思维森林在医疗AI编程中的应用蓝图
在医疗AI编程中,思维链(Chain of Thought, CoT)、思维树(Tree of Thoughts, ToT)、思维图(可能指知识图谱或逻辑图)以及思维森林(Forest-of-Thought, FoT)等技术框架通过模拟人类认知和推理过程,显著提升了AI在复杂医疗场景中的决策能力和可解释性: 1. 思维链(CoT)…...
SpringBoot异步任务实践指南:提升系统性能的利器
精心整理了最新的面试资料和简历模板,有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 引言 在现代Web应用中,高并发场景下的响应速度和资源利用率是系统设计的重要考量。SpringBoot通过简洁的异步任务机制,帮助开发者轻松…...
化工行业如何通过定制化工作流自动化实现25-30%成本优化?
作者:Mihir Jhaveri 编译:李升伟 发布日期:2024年10月30日 在化工生产领域,数字化转型正以颠覆性态势重塑产业格局。通过集成定制化软件、ERP系统、工业物联网(IIoT)传感网络、机器人流程自动化࿰…...
嵌入式硬件篇---嘉立创PCB绘制
文章目录 前言一、PCB绘制简介1.1绘制步骤1.1.1前期准备1.1.2原理图设计1.1.3原理图转PCB1.1.4PCB布局1.1.5布线1.1.6布线优化和丝印1.1.7制版1.2原理1.2.1电气连接原理1.2.2信号传输原理1.2.3电源和接地原理1.3注意事项1.3.1元件封装1.3.2布局规则1.3.3过孔设计1.3.4DRC检查1.…...
CSS Id 和 Class 选择器学习笔记
一、概述 在 CSS 中,id 和 class 选择器是用于为 HTML 元素指定样式的强大工具。它们可以帮助我们精确地控制页面中元素的样式,让页面设计更加灵活和高效。 二、id 选择器 1. 定义和使用 定义:id 选择器用于为具有特定 id 属性的 HTML 元素…...
Linux的 /etc/sysctl.conf 笔记250404
Linux的 /etc/sysctl.conf 笔记250404 /etc/sysctl.conf 是 Linux 系统中用于 永久修改内核运行时参数 的核心配置文件。它通过 sysctl 工具实现参数的持久化存储,确保系统重启后配置依然生效。以下是其详细说明: 📂 备份/etc/sysctl.conf t…...
LocaDate、LocalTime、LocalDateTime
Java8的时间处理 Java的时间处理在早期版本中存在诸多问题(如 java.util.Date 和 java.util.Calendar 的混乱设计),但Java8引入了引入了全新的 java.time包(基于JSR 310),提供了更清晰、线程安全且强大的时…...
1.Qt信号与槽
本篇主要介绍信号和槽,如何关联信号和槽以及用QPixmap在窗口中自适应显示图片 本文部分ppt、视频截图原链接:[萌马工作室的个人空间-萌马工作室个人主页-哔哩哔哩视频] 1. 信号 一般不需要主动发送信号,只有自定义的一些控件才需要做信号的…...
MySQL 基础入门
写在前面 关于MySQL的下载安装和其图形化软件Navicat的下载安装,网上已经有了很多的教程,这里就不再赘述了,本文主要是介绍了关于MySQL数据库的基础知识。 MySQL数据库 MySQL数据库基础 MySQL数据库概念 MySQL 数据库: 是一个关系型数据库管理系统 。 支持SQL语…...
shell语言替换脚本、填补整个命令行
shell语言替换脚本 填补整个命令行正则查询服务器指定路径替换内容 填补整个命令行 多用于脚本显示 seq -s "*" tput cols |tr -d [:digit:]正则查询 grep -r -E register[0-9]{5} /www/wwwroot服务器指定路径替换内容 #!/bin/bash cat > 1.sh << EOF #…...
数据分析与知识发现 论文阅读【信息抽取】
文章目录 基于知识蒸馏的半监督古籍实体抽取数据集模型实验结果 基于大语言模型的专利命名实体识别方法研究数据集评估公式实验 基于数据增强和多任务学习的突发公共卫生事件谣言识别研究数据集实验结果 参考 基于知识蒸馏的半监督古籍实体抽取 数据集 本文在有监督数据集的基…...
Compose组件转换XML布局
文章目录 学习JetPack Compose资源前言:预览界面的实现Compose组件的布局管理一、Row和Colum组件(LinearLayout)LinearLayout(垂直方向 → Column)LinearLayout(水平方向 → Row) 二、相对布局 …...
Linux开发工具——vim
📝前言: 上篇文章我们讲了Linux开发工具——apt,这篇文章我们来讲讲Linux开发工具——vim 🎬个人简介:努力学习ing 📋个人专栏:Linux 🎀CSDN主页 愚润求学 🌄其他专栏&a…...
Vue3学习二
认识组件的嵌套 还可以将Main中内容再划分 scoped防止组件与组件之间的样式相互污染 组件的通信 父子组件之间通信的方式 父组件传递给子组件 给传过来的内容做限制 type为传的内容的属性类型,required为true表示该内容是必须传的,default为,…...
[ deepseek 指令篇章 ]300个领域和赛道喂饭级deepseek指令
🍬 博主介绍 👨🎓 博主介绍:大家好,我是 _PowerShell ,很高兴认识大家~ ✨主攻领域:【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 🎉点赞➕评论➕收藏 养成习…...
2024第十五届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组
记录刷题的过程、感悟、题解。 希望能帮到,那些与我一同前行的,来自远方的朋友😉 大纲: 1、握手问题-(解析)-简单组合问题(别人叫她 鸽巢定理)😇,感觉叫高级了…...
C++ | C++11知识点
前言: 本篇内容讲述了C11中比较重要的内容为:右值引用、可变参数模板、lambda表达式和包装器。 ps:包装器博主在另一篇文章讲述的,本篇文章包装器板块为原文链接。 C11知识点目录 花括号初始化自定义类型的花括号初始化内…...
LeetCode 1123.最深叶节点的最近公共祖先 题解
昨天写了三题,今天目前为止写了一题,玩了会游戏稍微休息了下 先来理解一下今天的题目,今天的题目类型是递归遍历找最深位置,先通过几个样例了解一下 输入:root [3,5,1,6,2,0,8,null,null,7,4] 输出:[2,7,…...
C++设计模式-责任链模式:从基本介绍,内部原理、应用场景、使用方法,常见问题和解决方案进行深度解析
一、责任链模式的基本介绍 1.1 模式定义与核心思想 责任链模式(Chain of Responsibility Pattern)是一种行为型设计模式,其核心思想是将请求的发送者和接收者解耦。通过创建一个由多个处理节点组成的链条,每个节点依次尝试处理请…...
工具介绍 | SafeLLMDeploy教程来了 保护本地LLM安全部署
SafeLLMDeploy:保护本地大语言模型安全部署的“守护者” 在AI技术飞速发展的今天,大语言模型(LLM)如GPT、DeepSeek等正以前所未有的方式改变着我们的工作和生活。然而,本地部署这些强大的AI系统在带来便利的同时&…...
我该怎么设置SVN客户端的认证信息?
设置SVN客户端的认证信息通常取决于您使用的SVN客户端类型(命令行客户端或图形界面客户端)。以下是一些常见SVN客户端的设置方法: 1. 使用命令行SVN客户端 对于命令行SVN客户端,您通常在执行SVN命令时直接输入用户名和密码&…...
机器学习-04-分类算法-03KNN算法案例
实验名称 K近邻算法实现葡萄酒分类 实验目的 通过未知品种的拥有13种成分的葡萄酒,应用KNN分类算法,完成葡萄酒分类; 熟悉K近邻算法应用的一般过程; 通过合理选择K值从而提高分类得到正确率; 实验背景 本例实验…...
AIP-213 通用组件
编号213原文链接AIP-213: Common components状态批准创建日期2018-08-17更新日期2018-08-17 根据AIP-215规定,除使用“通用组件”包之外,API必须是独立的。通用组件包是给多个API使用的。 通用组件包有两种类型: 组织特定的通用组件&#…...
Go语言-初学者日记(七):用 Go 写一个 RESTful API 服务!
👷 实践是最好的学习方式!这一篇我们将用 Go Gin 框架从零开始开发一个用户管理 API 服务。你将学到: 如何初始化项目并引入依赖如何组织目录结构如何用 Gin 实现 RESTful 接口如何通过 curl 测试 API进阶功能拓展建议 🧰 一、项…...
Java 搭建 MC 1.18.2 Forge 开发环境
推荐使用 IDEA 插件 Minecraft Development 进行创建项目 创建完成后即可进行 MOD 开发。 但是关于 1.18.2 的开发教程太少,因此自己研究了一套写法,写法并非是最优的但是是探索开发MOD中的一次笔记和记录 GITHUB: https://github.com/zimoyin/zhenfa…...
计算机网络知识点汇总与复习——(三)数据链路层
Preface 计算机网络是考研408基础综合中的一门课程,它的重要性不言而喻。然而,计算机网络的知识体系庞大且复杂,各类概念、协议和技术相互关联,让人在学习时容易迷失方向。在进行复习时,面对庞杂的的知识点,…...
