IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:oracle

共 201 篇相关文章

IT 累计浏览 2,549

Oracle 各种删除操作对空间返还的说明

DBA们常常遇到这样的困惑:对Oracle表执行DELETE、DROP还是TRUNCATE?这些操作对空间到底有何影响?这篇技术说明正是为厘清这些差异而写。 文章将三种常见删除操作(DELETE SQL、DROP TABLE、TRUNCATE TABLE)放在一起对比,从多个维度拆解其不同。关键差异点包括:DELETE操作不会将空间归还给表空间或文件系统,空间仅能被原表重用,但可能产生“高水位”;而DROP和TRUNCATE默认都会释放表空间,但依然不会自动收缩数据文件。此外,在本地管理表空间下,这些操作基本不会造成表空间碎片,但在老旧的字典管理表空间中,DROP和TRUNCATE则可能导致碎片。 对于追求“干净”释放空间的场景,文章也给出了务实建议:例如使用`shrink space`整理表,或对索引执行`coalesce`。最终目的是帮助DBA们根据实际需求(是彻底删除、快速清空还是谨慎释放)选择合适的操作,并管理好预期——Oracle默认不会自动将空间返还给操作系统。

IT 累计浏览 2,291

《Effective java》—–读书笔记

读完《Effective Java》后,作者结合自己的面试反思与年度学习计划,写下这篇笔记,摘录并梳理了书中多条核心原则。笔记从创建对象讲起,强调了静态工厂方法的优势、避免创建不必要对象以及如何通过私有构造器或枚举强化单例。接着,重点讨论了类与接口设计:最小化可访问性、为不可变性努力、优先使用组合而非继承、以及如何用接口定义类型和用骨架实现类弥补抽象类的不足。 在方法层面,笔记总结了慎用重载和可变参数、返回零长度数组而非null等实用建议。通用编程部分则归纳了最小化局部变量作用域、优先使用for-each循环和基本类型等性能与可读性并重的技巧。最后,笔记也提到了异常处理的原则——异常应只用于异常情况。 这些笔记摘录不仅保留了原著的精华论点,还结合了博主自己的理解,如通过WeakHashMap管理缓存、继承判断的“is-a”原则等,将“四大圣经”之一的实践智慧转化为开发者可直接参考的要点清单。

IT 累计浏览 3,145

一次临时表空间大量占用问题的处理

这篇讲的是如何诊断和解决一个核心交易系统临时表空间暴涨至600GB的问题。作者从实际案例出发,发现占用临时空间的大量排序段,并非由当前执行的SQL产生,而是源于大量会话打开了需要复杂排序的查询游标后,一直没有关闭,导致Oracle必须维持这些游标的状态和已排序的数据,从而长期占用临时段。 文章详细展示了排查过程:通过v$sort_usage定位到大量会话关联同一个SQL_ID,但发现该SQL本身并不需要排序。真正的“元凶”是这些会话中打开的另一个游标——一条对千万级数据进行排序的业务查询。由于应用在取数后未正确关闭游标,使得排序段无法释放。作者甚至用PL/SQL代码复现了这一过程,清晰演示了临时空间是如何被一个未关闭的游标“泄漏”出去的。 这篇案例的精彩之处在于,它纠正了一个常见误区,并提供了一套实用的诊断思路:当遇到临时表空间异常时,应重点检查会话的打开游标,特别是那些有大量排序操作且未完成处理的SQL,而不仅仅是看当前正在执行的语句。

IT 累计浏览 2,465

Oracle 11g大对象数据新技术

这篇内容专门针对 Oracle 数据库中令人头疼的 ORA-00600 内部错误,提供了一套从定位到解决的系统化诊断手册。它首先点明,这类错误本质上是 Oracle 软件遇到了不一致的低级异常,成因可能涉及 Bug、操作系统或硬件。 文章的核心价值在于其清晰的排查路径:第一步永远是检查 alert.log 和 trace 文件;第二步是利用 Metalink 提供的专用诊断工具,通过输入错误的第一个参数和数据库版本号快速检索知识库;第三步则是整理必要信息,向 Oracle Support 提交 SR。 作者特别强调了 trace 文件的完整性和参数信息的关键作用,并用“ORA-00600 [729]”空间泄漏的实例,演示了如何通过设置特定事件参数来规避这类可忽略的内存泄漏告警。整体而言,文章将复杂的内部错误排查流程,拆解成了可操作的步骤,对 DBA 构建故障处理预案很有参考价值。

IT 累计浏览 3,207

那些常见的Oracle错误

这篇讲的是Oracle数据库运维中那些高频出现的“拦路虎”。作者从DBA经常面临的实际故障现场出发,梳理了ORA-00600、内存耗尽、空间不足等几类典型问题。文章不止于罗列现象,而是深入到了问题的“肌理”——比如ORA-00600这类内部错误,其第一个参数和数据库版本就是定位根因的钥匙;ORA-04030则往往与PGA内存分配和操作系统限制有关。 更实用的部分在于诊断思路。文章引导读者从检查alert.log和trace文件入手,还指出了Oracle官方在Metalink上提供的600/7445诊断工具这个利器。针对具体案例,如ORA-00600[729]“UGA空间泄露”,给出了设置事件参数“10262”来屏蔽小泄露的明确解决方案。这种“故障现象-诊断方法-官方工具-具体参数”的完整链条,为运维人员构建了一套可复用的排查预案,能有效降低面对突发故障时的手足无措感。

IT 累计浏览 2,604

Oracle字符类型存数字及查询数字时使用单引号走不走索引的问题

这篇文章解决的是一个在实际数据库开发中容易产生争议的问题:用varchar2类型存放的数字字段,在查询条件中给数字加上单引号,到底会不会导致索引失效?作者从团队内部的实际分歧出发,通过在Oracle 11.2.0.4.0版本上进行测试来验证结论。 文章首先通过建表和数据准备,复现了讨论的场景。核心对比点在于两种常见的错误认知:一种是认为“char类型存数字,查询不加单引号不走索引”;另一种则想验证“varchar2类型存数字,查询加单引号是否还会走索引”。作者通过具体的执行计划截图(文中虽未显示但提到测试信息),清晰地展示了不同写法下的索引使用情况。 最终得出了明确的结论:对于varchar2类型字段,无论在查询时是否为数字加上单引号,都能正常走索引。这个结果厘清了一个常见的误解,并为后续将varchar2字段改为number类型的设计决策提供了数据支持。对于DBA和开发人员而言,理解数据库在处理隐式类型转换时的具体行为,有助于编写出既准确又高效的SQL语句。

IT 累计浏览 2,808

Oracle正则表达式使用小结

这篇文章梳理了Oracle数据库从10g开始支持的正则表达式功能。作者将匹配逻辑集中在数据库端,可以避免在中间层处理,从而简化开发。文章概要总结了Oracle中使用正则表达式的核心方法。 内容重点介绍了五个关键的正则表达式函数:REGEXP_LIKE 用于条件过滤,REGEXP_COUNT 能统计模式出现次数,REGEXP_INSTR 可定位首次匹配位置,REGEXP_REPLACE 支持模式替换,REGEXP_SUBSTR 则能提取满足模式的字符串。每个函数都配有清晰的SQL示例。 除了函数用法,文章还梳理了控制匹配行为的选项,比如忽略大小写的“i”、多行模式“m”等,并通过示例解释了不同选项带来的具体差异。此外,文中也列举了如“.”“+”“*”等常见元字符及其含义,为实际编写匹配模式提供了参考。

IT 累计浏览 2,534

使用审计功能记录错误密码登陆信息

这篇讲的是如何利用Oracle数据库内置的审计功能,来定位UAT环境中用户频繁被锁定的根本原因。 在一次UAT环境恢复后,业务用户不断反映账户被锁定,且每个人都坚称自己输入的密码无误。作者原本打算新建触发器来记录错误登录尝试,但在检查配置时发现,当前使用的Oracle 11.2.0.4数据库,默认的审计功能实际上是开启的。 通过执行`show parameter audit`命令确认状态后,作者直接从审计日志入手,查询了`dba_audit_trail`视图。最终清晰地定位到问题根源:某个应用程序在连接时持续使用了错误的密码。审计日志详细记录了尝试登录的客户端程序、操作系统用户、终端以及具体时间,证据确凿。这不仅快速解决了“谁在用错密码”的罗生门,也避免了额外编写监控代码的开销。 这个案例提醒我们,在进行故障排查时,先摸清数据库现有功能与配置至关重要。Oracle默认开启的审计机制,就像一位默默工作的哨兵,在无需额外开发的情况下,为我们保留了关键的现场证据。

IT 累计浏览 3,063

ORACLE怎样将CHAR类型字段转换成CLOB

这篇讲的是Oracle数据库中一个常见但细节不少的字段类型转换问题。文章直接切入实操,演示了如何将CHAR类型的字段转换为CLOB类型。它分了两种场景来具体说明:一种是目标列当前为空,另一种是列中已经存放了数据。 针对这两种情况,文章分别给出了转换的SQL思路和操作步骤。对于空列,操作可能相对直接,而列中已有数据时,则需要考虑数据的迁移与处理。通过具体的表结构示例(比如sdb_b2c_goods表)和代码演示,让读者能清晰地看到每一步操作。 对于需要调整表结构、迁移大文本数据的开发者或DBA来说,这篇文章提供了一个非常清晰的、分场景的解决方案参考,避免了自己摸索可能遇到的数据丢失或转换错误问题。

IT 累计浏览 2,345

ORACLE和SYBASE数据库中实现数据查询条数限制的SQL语句实现

这篇技术分享讲的是一个常见但容易混淆的数据库操作细节:如何在查询时限制返回的数据条数。作者以一个包含7条记录的员工信息表为例,分别演示了在ORACLE和SYBASE两种主流数据库中的实现方式。 在ORACLE中,核心是利用伪列`rownum`,直接在`WHERE`子句中加入`rownum <= 5`这样的条件即可,简洁直观。而在SYBASE里,则需要通过`set rowcount 5`语句来设置,但紧接着必须用`set rowcount 0`将其重置,否则这个限制会持续影响后续所有查询操作,这是一个需要特别注意的关键陷阱。 文章的价值在于,通过最简单的示例,清晰地揭示了这两种数据库在语法和用法逻辑上的根本差异。对于需要处理海量数据、必须进行分批查询以保证系统稳定性的开发者而言,掌握这些具体语法并警惕其中的“坑”,是写出高效、健壮SQL语句的基础。

IT 累计浏览 3,344

在ORACLE 12C RAC中使用in memory特性请注意parallel_degree_policy和parallel_force_local参数

这是一篇典型的故障排查文章。作者在对Oracle 12C RAC的In-Memory特性进行测试时,遇到了一个棘手的问题:在清空缓冲区缓存后,测试总是意外触发大量并行操作,导致结果不准确。 经过与Oracle官方协作排查,最终定位到问题的根源在于两个关键参数的默认设置不匹配In-Memory的最佳实践。具体来说,参数`parallel_degree_policy`被设为了`AUTO`,而`parallel_force_local`则是默认的`false`。在RAC环境下,这种组合会导致并行执行计划不符合预期。 文章通过具体的SQL操作和执行计划对比,清晰地展示了问题表现:从执行计划中可以看到“automatic DOP: Computed Degree of Parallelism is 2”的提示,并且明确标注了“parallel scans affinitized for inmemory”,这证实了In-Memory特性已被触发。解决方法就是根据RAC环境的需要,正确调整这两个参数的值。 对于计划在RAC集群中使用In-Memory功能的DBA来说,这篇文章提供了一个非常实用的避坑指南。它提醒我们,在启用强大的新特性时,往往需要仔细检查并调整相关的并行处理参数,才能确保其发挥出应有的性能优势。

IT 累计浏览 2,542

给你的rman备份集加上密码锁

备份是数据保护的最后一道防线,但如果备份集本身没有防护,泄露的风险同样存在。这篇文章从这个角度出发,讲解了如何为Oracle RMAN备份集加上密码锁,实现加密存储。 作者从数据安全的现实威胁切入,指出RMAN备份集若被窃取,其数据风险等同于生产库被入侵。解决方案是利用RMAN在10.2及以上企业版中提供的`set encryption`命令,在备份过程中直接设置加密密码。文章详细演示了从配置加密算法(支持AES128/AES256等)到执行加密备份的完整步骤,并特别提醒:加密仅对`backupset`有效,`copy`方式不支持;若需备份到带库,则必须使用Oracle Secure Backup。 最具说服力的部分是实操验证。作者创建了测试表空间和数据,进行了加密备份,随后模拟数据文件丢失并尝试恢复。结果显示,在不知道密码的情况下恢复会报错;即使设置错误密码也无法成功。只有使用正确的密码才能顺利完成恢复,这直观地证明了加密机制的有效性。 整篇文章实操性强,不仅提供了命令行的具体操作,更通过正反验证让读者清晰看到加密带来的保护效果,对于关注数据库备份安全性的DBA来说,是一个直接可落地的加固方案。

IT 累计浏览 2,848

怎么查看oracle ebs的系统版本号以及各模块的版本号

这篇讲的是如何快速定位Oracle EBS的版本信息,这是系统管理和升级时的一个基础但关键的步骤。作者没有绕弯子,直接切入核心需求:如何查看系统整体版本号,以及如何深入查看每个应用模块的具体版本、安装状态和补丁级别。 文章提供了两个现成的SQL查询,分别用于获取系统级版本(从`fnd_product_groups`表)和模块级详情(关联`fnd_product_installations`与`fnd_application`表)。作者特意点明,这类信息查询的关键线索通常在于以`fnd_`为前缀的系统表。对于需要进行版本核对、补丁安装前检查或环境排查的EBS顾问与DBA来说,这几行查询能直接给出准确答案,避免了在界面上层层点击的繁琐。

IT 累计浏览 2,423

修改oracle当前会话的语言环境,解决oracle显示中文乱码的问题

这篇讲的是如何快速解决Oracle数据库在操作时出现中文提示显示为一串问号的常见问题。 作者从实际操作中的困扰出发,明确指出这种乱码的根源在于当前会话的语言环境设置不匹配。文章提供了具体、可操作的解决方案:首先通过 `SELECT userenv('language') FROM dual;` 命令来查看当前的语言环境配置,确认问题。接着,给出了两种修改方法:一是通过 `ALTER SESSION SET NLS_LANGUAGE='SIMPLIFIED CHINESE';` 命令临时修改当前会话,使其立即生效;二是通过修改环境变量等方式进行永久性设置,从根源上避免问题再次出现。 整个排查思路清晰,步骤直接,对于遇到类似字符集显示问题的数据库管理员或开发人员来说,是一份实用且能快速解决问题的参考。简单几条命令就能让提示信息恢复可读性,提升了工作效率。

IT 累计浏览 2,947

oracle跟踪事件(dump)总结

这篇讲的是Oracle数据库中用于故障诊断的跟踪事件(dump)机制。文章系统梳理了跟踪文件的三种类型——后台报警日志、后台进程跟踪文件和用户跟踪文件,并详细说明了如何通过初始化参数或会话命令来触发dump操作。 核心内容聚焦于各种跟踪事件的具体用法。例如,通过`buffers`事件可导出SGA缓冲区信息,`blockdump`事件能定位特定数据块,`errorstack`事件则用于捕获难以获取的错误栈。文章还列举了诸如`10046`(SQL语句跟踪)、`10231`(全表扫描时跳过损坏块)等实用的内部事件号,并解释了其参数级别含义。 最后,文章提供了查看当前跟踪文件的简单示例。整体上,它像一份面向DBA和开发者的速查手册,将分散的Oracle诊断工具整理成可操作的条目,便于在性能调优或故障排查时快速定位并转储关键内存结构或日志信息。

IT 累计浏览 2,126

Oracle数据库升级迁移、SPA及统计信息

作者从一次真实的升级迁移讲起:某省级电信运营商将核心CRM系统的Oracle数据库,从IBM小型机上的10g RAC迁移至x86+VMware平台的11g RAC,成本降至十分之一。这引出了一个关键的后续问题:新系统上线后,应采用何种统计信息收集策略? 文章对比了两种方案:迁移旧库统计信息或在新库自动收集。作者团队最终选择了后者,原因是11gR2的自动收集机制已相对完善,且能为后续运维降低风险。但如何确保这一策略在上线时就安全可用?答案在于利用SPA(SQL性能分析器)。 团队使用了生产库三个时段及一个月AWR中的全部SQL,在新库上跑SPA测试。在测试前,先用`dbms_stats.gather_database_stats(options=>'gather auto')`执行一次增量收集。然而,直接这样做会导致新库的直方图信息严重缺失,因为自动收集依赖`col_usage$`表,而新库此表为空。解决方法是在SPA测试过程中,通过执行足够多的SQL来“喂饱”`col_usage$`,让系统“记住”哪些列需要被关注。最终,基于SPA的测试结果,用数十个SQL Profile固化了风险计划,保障了系统平稳上线。 这篇分享的价值在于,它清晰地展示了在大型跨版本迁移中,如何通过组合使用SPA和自动统计信息收集策略,来系统性规避性能风险,而不仅仅是凭经验手工调优。

IT 累计浏览 1,382

Oracle中的Low HWM与 High HWM 高水位

这篇讲的是Oracle数据库在ASSM存储管理下,如何通过引入Low HWM和High HWM两个高水位标记来优化存储空间利用与并发性能。作者从传统MSSM模式下单一高水位标记的局限性切入,指出了其可能引发的锁竞争与IO性能问题。 文章核心聚焦于ASSM的解决方案:通过两个高水位将数据块区域划分为已格式化(Low HWM以下)、未格式化但可能被重用(Low HWM与High HWM之间)以及完全未格式化(High HWM以上)三个区域。这种设计精妙之处在于,它允许在HWM以下存在未格式化的“空洞”,从而在直接路径加载数据时,能更灵活地复用空间,避免因频繁提升高水位而导致的锁等待和不必要的格式化IO开销。 作者进一步解释了这一机制的关键细节:只有当当前extent及之前extent中的所有块均被格式化后,Low HWM才会上升;而High HWM的提升则与一级位图块管理的范围相关。在顺序读取时,系统以High HWM为终点,同时忽略其间未格式化的块,保证了查询效率。整篇内容深入到底层实现原理,为理解Oracle复杂的存储管理提供了清晰的视角。

IT 累计浏览 2,390

Oracle JDBC中的语句缓存

这篇讲的是如何在Java应用中,利用Oracle JDBC驱动提供的语句缓存机制,来优化数据库访问性能,核心目标是实现“一次解析,多次执行”的高效模式。 文章首先清晰梳理了Oracle数据库中硬解析、软解析等不同SQL解析方式的特点与潜在性能瓶颈,指出过多解析会导致latch争用等问题。随后,作者通过一个对比实验,直观展示了开启JDBC语句缓存前后的巨大差异:未缓存时,一条SQL语句执行200次就产生了200次解析;而开启缓存后,同样执行200次,解析次数仅为1次,显著降低了数据库负载。 实现的关键在于通过OracleConnection对象设置`setStatementCacheSize`和`setImplicitCachingEnabled`,这能为每个连接自动缓存使用过的PreparedStatement。文章还深入一层,介绍了如何通过`setExplicitCachingEnabled`及手工指定Key的方式,进行更精细的缓存控制,以避免缓存不常用语句造成的内存浪费。 通过具体的代码示例与数据库监控结果验证,文章为Java开发者提供了一个实用且效果明确的Oracle性能优化方案。

IT 累计浏览 2,645

如何提高Oracle进程的优先级 - 实现进程实时调度

这篇讲的是在繁忙的Oracle系统中,如何为关键后台进程争取更多的CPU资源。作者从Oracle 10gR2引入的一个隐含参数 **_high_priority_processes** 出发,介绍了实现进程实时调度的具体方法。 文章核心是讲解这个参数的使用:通过在数据库中设置它(例如 `_high_priority_processes="LMS*|LGWR|PMON"`),可以提升指定进程的优先级。作者通过Linux下的实际测试展示了效果:设置前PMON进程为普通分时调度(TS),重启数据库后即转变为实时调度(RR),从而能优先获取CPU。文章还对比了不同操作系统下的差异,例如Solaris上会使用RT实时模式。 最后,作者也提醒了实际应用中的细节,比如在RAC环境中,提升所有LMS进程的优先级可能并非必要,反而会抢占资源,需要根据业务负载审慎配置。整篇文章从原理、设置方法到实际效果和注意事项,提供了一套完整的技术思路。

IT 累计浏览 4,348

Oracle Database 12c架构图

这篇讲的是Oracle Database 12c的架构全景图。作者提供了两张高清图表,一张完整勾勒了12c的整体架构,清晰地展示了所有关键组件以及它们之间的关系,特别是那些在新版本中引入或调整的后台进程,并简要说明了它们的工作原理。另一张则专门聚焦于12c最引人注目的特性——多租户(Pluggable Database)架构。这张大图详细描绘了容器数据库(CDB)与可插拔数据库(PDB)之间的交互逻辑,将这种能大幅提升资源利用率和管理效率的新模式,以可视化的方式呈现得一目了然。对于需要快速理解Oracle 12c技术演进方向、或正在规划数据库升级的团队来说,这两张图提供了非常直接的架构参考。图文结合的方式,让抽象的数据库内核设计变得直观可感。