踩了三天坑,我决定重新写
第一天我把Oracle那套存储过程改吧改吧塞进disql里执行。disql报错输入过长。行拆成两个文件。能跑了但维护起来太麻烦改一个地方得改两个文件。第二天我对着达梦的官方文档一个一个视图去对列名。这才发现达梦的系统视图跟Oracle差异巨大——V$INSTANCE里没有STATUS列人家叫STATUS$没有SV_VERSION叫SVR_VERSIONV$SQL_HISTORY里找不到EXEC_TIME得用TIME_USED单位还是微秒。折腾了一整天改了五六轮终于能跑通了。第三天我在脚本里加了几行提示信息写的是PROMPT [备份] Transaction Info。结果disql弹出一个输入提示要我输入Transaction的值。我这才知道disql会把PROMPT后面的英文单词当成变量名来解析。三天下来我悟了别整花活老老实实用纯SQL。于是有了下面这套脚本——12个独立SQL文件每个10到38行不建任何存储过程、函数、视图对生产库零侵入。直接在disql里执行就行跑完就出结果。01. 实例基本信息 —01_instance.sql-- 实例基本信息 (使用 V$INSTANCE 真实列名) SELECT INSTANCE_NAME, HOST_NAME, SVR_VERSION AS VERSION, DB_VERSION, TO_CHAR(START_TIME, YYYY-MM-DD HH24:MI:SS) AS START_TIME, STATUS$ AS STATUS, MODE$ AS MODE_TYPE, DSC_ROLE AS DSC_ROLE FROM V$INSTANCE;看什么实例名、主机名、版本、启动时间、运行状态。常见问题STATUS$为空或者不是预期值说明实例可能有问题。DSC_ROLE在单机环境通常是NULL集群环境才会显示节点角色。注意DM8的列名带$后缀跟Oracle不一样别搞混。02. 内存参数 —02_memory.sqlSELECT NAME AS PARAM_NAME, ROUND(VALUE/1024/1024, 2) AS VALUE_MB, CASE TYPE WHEN 1 THEN static WHEN 2 THEN dynamic ELSE other END AS TYPE_DESC FROM V$PARAMETER WHERE NAME IN (MAX_MEMORY,MEMORY_POOL,BUFFER, MAX_BUFFER_SIZE,BUFFER_POOLS) ORDER BY NAME;看什么最大内存上限、内存池大小、缓冲区大小。常见问题MAX_MEMORY设得太小会导致数据库OOMBUFFER显示为0.01MB通常意味着启用了动态缓冲区管理这是正常现象MEMORY_POOL过小会影响排序和哈希操作的性能。03. 表空间使用率⭐核心告警—03_tablespace.sqlSELECT A.TABLESPACE_NAME, ROUND(A.TOTAL_SIZE*8192/1024/1024, 2) AS TOTAL_MB, ROUND(B.FREE_SIZE*8192/1024/1024, 2) AS FREE_MB, ROUND((A.TOTAL_SIZE-B.FREE_SIZE)*8192/1024/1024, 2) AS USED_MB, ROUND((A.TOTAL_SIZE-B.FREE_SIZE)*100.0/NULLIF(A.TOTAL_SIZE,0), 2) AS USED_PCT, C.STATUS, CASE WHEN (A.TOTAL_SIZE-B.FREE_SIZE)*100.0/NULLIF(A.TOTAL_SIZE,0) 85 THEN !! WARN ELSE OK END AS FLAG FROM ( SELECT TABLESPACE_NAME, SUM(BYTES) TOTAL_SIZE FROM DBA_DATA_FILES GROUP BY TABLESPACE_NAME ) A, ( SELECT TABLESPACE_NAME, SUM(BYTES) FREE_SIZE FROM DBA_FREE_SPACE GROUP BY TABLESPACE_NAME ) B, ( SELECT DISTINCT TABLESPACE_NAME, STATUS FROM DBA_DATA_FILES ) C WHERE A.TABLESPACE_NAMEB.TABLESPACE_NAME() AND A.TABLESPACE_NAMEC.TABLESPACE_NAME() ORDER BY USED_MB DESC;看什么每个表空间的总大小、已用大小、使用率百分比超过85%会标记!! WARN。常见问题MAIN表空间使用率接近100%时数据库就无法写入新数据了这是生产环境最高优先级的告警。达梦页大小默认8KB所以计算时用*8192转成MB——如果你建库时指定了不同的页大小这个值要相应调整。04. 数据文件Top15 —04_datafile.sqlSELECT FILE_ID, TABLESPACE_NAME, FILE_NAME, ROUND(BYTES/1024/1024, 2) AS SIZE_MB, AUTOEXTENSIBLE, ROUND(MAXBYTES/1024/1024, 2) AS MAXSIZE_MB, STATUS FROM DBA_DATA_FILES ORDER BY BYTES DESC LIMIT 15;看什么最大的15个数据文件以及它们是否开启了自动扩展。常见问题AUTOEXTENSIBLENO且SIZE_MB快要到MAXSIZE_MB的文件是最先可能出问题的。另外留意一下数据文件是不是分布在系统盘生产环境应该放在专用数据盘上。05. 会话统计与活跃会话 —05_session.sql-- 会话汇总 SELECT COUNT(*) AS TOTAL_SESSIONS, COUNT(CASE WHEN STATEACTIVE THEN 1 END) AS ACTIVE_SESSIONS, COUNT(CASE WHEN STATE!ACTIVE THEN 1 END) AS INACTIVE_SESSIONS, CASE WHEN COUNT(*) 200 THEN !! EXCEEDS THRESHOLD ELSE OK END AS FLAG FROM V$SESSIONS; -- Active Sessions TOP15 SELECT SESSID, USER_NAME, CLNT_IP AS CLIENT_IP, STATE, APPNAME, LEFT(SQL_TEXT,60) AS SQL_TEXT, LAST_RECV_TIME, ROUND((SYSDATE-LAST_RECV_TIME)*86400, 0) AS IDLE_SEC FROM V$SESSIONS WHERE STATEACTIVE ORDER BY IDLE_SEC ASC LIMIT 15;看什么会话总数超过200会告警、活跃/非活跃会话数量、当前正在执行的SQL。常见问题活跃会话突然飙升通常意味着有锁等待或大量慢查询堆积。非活跃会话大量积压说明应用连接池没有正确释放连接。CLNT_IP字段如果是IPv6格式如::ffff:172.x.x.x需要手动转换一下看真实IP。06. 锁等待与长事务 —06_lock.sql-- 6.1 锁等待数量 SELECT COUNT(*) AS LOCK_WAIT_COUNT FROM V$TRXWAIT; -- 6.2 锁等待详情 (V$TRXWAIT: ID等待事务ID, WAIT_FOR_ID阻塞事务ID) SELECT ID AS WAIT_TRX_ID, WAIT_FOR_ID AS HOLD_TRX_ID FROM V$TRXWAIT WHERE ROWNUM 20; -- 6.3 当前活跃事务 (V$TRX 真实列) SELECT ID AS TRX_ID, SESS_ID, STATUS AS TRX_STATUS, ISOLATION, READ_ONLY FROM V$TRX WHERE STATUS COMMIT ORDER BY ID LIMIT 20;看什么锁等待数量、谁在等谁、当前未提交的事务。常见问题LOCK_WAIT_COUNT 0说明存在事务阻塞需要立即排查。死锁信息不在视图里得去dmserver.log搜DEADLOCK关键字。注意V$TRX的列名是ID不是TRX_ID、SESS_ID不是SESSION_ID这里跟Oracle完全不同。我特意把三个查询拆开写不做JOIN因为disql对复杂JOIN的解析容易出问题。07. 备份与归档配置 —07_backup.sql

相关新闻

软考2025新增“AI工程能力”模块?官方未官宣但已嵌入大纲(附2025考试权重预测表)

软考2025新增“AI工程能力”模块?官方未官宣但已嵌入大纲(附2025考试权重预测表)

更多请点击: https://kaifayun.com 第一章:软考2025“AI工程能力”模块的政策演进与定位 2025年全国计算机技术与软件专业技术资格(水平)考试(简称“软考”)首次将“AI工程能力”设为独立考核模块&#xf…

2026/6/29 3:27:47阅读更多 →
【Qt6】VS中CMake配置疑难杂症:从路径缺失到工具链依赖

【Qt6】VS中CMake配置疑难杂症:从路径缺失到工具链依赖

1. Qt6与CMake环境配置的常见问题 刚接触Qt6开发的朋友,在Visual Studio中使用CMake构建项目时,经常会遇到各种配置问题。最常见的就是QT_DIR路径找不到,或者Qt6CoreTools等工具链依赖缺失。这些问题看似简单,但如果不了解背后的原…

2026/6/29 3:27:47阅读更多 →
SEBD框架:量子动力学模拟中的纠缠熵抑制技术

SEBD框架:量子动力学模拟中的纠缠熵抑制技术

1. SEBD框架概述:量子动力学模拟的新范式在量子多体系统的动力学模拟领域,纠缠熵的线性增长一直是制约传统张量网络方法的主要瓶颈。SEBD(Spatially Entangled Block Decimation)框架通过创新性地结合因果光锥演化与投影测量&…

2026/6/29 3:27:47阅读更多 →
从单 Agent 到多 Agent:为什么协作难落地

从单 Agent 到多 Agent:为什么协作难落地

Agent 再强大,面对跨领域的复杂任务,终究会遇到能力边界。一个「点咖啡」的 Agent 不应该知道怎么「安排配送」,一个「写代码」的 Agent 不应该知道怎么「审批流程」。更合理的方式,是让不同 Agent 各司其职,再通过协作…

2026/6/29 4:42:54阅读更多 →
如何快速掌握YimMenu:免费GTA5辅助工具的完整配置与安全使用指南

如何快速掌握YimMenu:免费GTA5辅助工具的完整配置与安全使用指南

如何快速掌握YimMenu:免费GTA5辅助工具的完整配置与安全使用指南 【免费下载链接】YimMenu YimMenu, a GTA V menu protecting against a wide ranges of the public crashes and improving the overall experience. 项目地址: https://gitcode.com/GitHub_Trendi…

2026/6/29 4:42:54阅读更多 →
BiRefNet:高分辨率双边参考图像分割技术革新

BiRefNet:高分辨率双边参考图像分割技术革新

BiRefNet:高分辨率双边参考图像分割技术革新 【免费下载链接】BiRefNet [CAAI AIR24] Bilateral Reference for High-Resolution Dichotomous Image Segmentation 项目地址: https://gitcode.com/gh_mirrors/bi/BiRefNet BiRefNet作为CAAI AIR 2024期刊发表的…

2026/6/29 4:42:54阅读更多 →
RA8M2超低功耗定时器与实时时钟实战指南

RA8M2超低功耗定时器与实时时钟实战指南

1. 项目概述与核心价值在嵌入式开发,尤其是电池供电的物联网设备中,如何平衡功能实现与功耗控制,是每个工程师必须面对的“灵魂拷问”。RA8M2作为一款高性能的Arm Cortex-M85内核微控制器,其内置的超低功耗定时器(ULPT…

2026/6/29 4:42:52阅读更多 →
ChatGPT验证页空白/无限转圈/返回错误代码429?工程师私藏的8行curl调试脚本+Cloudflare绕过技巧(限前200名领取)

ChatGPT验证页空白/无限转圈/返回错误代码429?工程师私藏的8行curl调试脚本+Cloudflare绕过技巧(限前200名领取)

更多请点击: https://kaifayun.com 第一章:ChatGPT手机号验证的底层机制与常见失效场景 ChatGPT 的手机号验证并非简单的短信发送与比对,而是依托 OpenAI 后端的多层风控体系实现。其核心流程包含设备指纹采集、IP信誉评估、SIM卡生命周期校…

2026/6/29 4:42:52阅读更多 →
抖音无水印下载终极指南:三步实现高清视频本地化

抖音无水印下载终极指南:三步实现高清视频本地化

抖音无水印下载终极指南:三步实现高清视频本地化 【免费下载链接】douyin_downloader 抖音短视频无水印下载 win编译版本下载:https://www.lanzous.com/i9za5od 项目地址: https://gitcode.com/gh_mirrors/dou/douyin_downloader 在数字内容创作日…

2026/6/29 4:37:51阅读更多 →
AI Coding 六个月真实ROI账本:产品经理的血泪教训,研发的冷静忠告

AI Coding 六个月真实ROI账本:产品经理的血泪教训,研发的冷静忠告

6个月前的2025年12月,Boris Cherny 公开宣布自己卸载了 IDE。一时间,Vibe Coding 成了全行业最热的话题。6个月后,当我们回过头来拉一份真实账本,发现事情远没有"一句话生成一个App"那么浪漫。本文从产品经理和研发两个…

2026/6/29 3:27:55阅读更多 →
审计来了,数据权限全开——审计走了,怎么确保权限全部关掉?

审计来了,数据权限全开——审计走了,怎么确保权限全部关掉?

引言:审计结束三个月了,审计员的权限还没关某城商行每年按照监管要求开展至少一次数据安全审计。审计期间,内审部门需要抽样检查各类业务数据——交易流水、客户信息、员工操作日志、权限配置记录。这些数据分布在不同系统中,审计…

2026/6/29 2:19:08阅读更多 →
如何在3秒内从普通图片生成专业级法线贴图:DeepBump的终极指南

如何在3秒内从普通图片生成专业级法线贴图:DeepBump的终极指南

如何在3秒内从普通图片生成专业级法线贴图:DeepBump的终极指南 【免费下载链接】DeepBump Normal & height maps generation from single pictures 项目地址: https://gitcode.com/gh_mirrors/de/DeepBump 还在为3D建模中的纹理制作而烦恼吗?…

2026/6/29 0:01:47阅读更多 →
OCAuxiliaryTools:终极OpenCore配置工具,让黑苹果安装从未如此简单!

OCAuxiliaryTools:终极OpenCore配置工具,让黑苹果安装从未如此简单!

OCAuxiliaryTools:终极OpenCore配置工具,让黑苹果安装从未如此简单! 【免费下载链接】OCAuxiliaryTools Cross-platform GUI management tools for OpenCore(OCAT) 项目地址: https://gitcode.com/gh_mirrors/oc/OCA…

2026/6/29 0:01:47阅读更多 →
终极Windows 11精简指南:使用tiny11builder快速创建纯净系统镜像

终极Windows 11精简指南:使用tiny11builder快速创建纯净系统镜像

终极Windows 11精简指南:使用tiny11builder快速创建纯净系统镜像 【免费下载链接】tiny11builder Scripts to build a trimmed-down Windows 11 image. 项目地址: https://gitcode.com/GitHub_Trending/ti/tiny11builder 你是否厌倦了Windows 11系统自带的20…

2026/6/29 0:01:47阅读更多 →