MySQL怎样在触发器中引用新旧数据行_NEW与OLD关键字详解

DB_FILE_NAME_CONVERT必须配置成对路径前缀,因其按"主库路径前缀→备库路径前缀"精确匹配替换,不支持通配符或模糊匹配,且两端必须带结尾斜杠、大小写敏感;若主库路径不以指定前缀开头则完全失效,导致ORA-01119等错误。DB_FILE_NAME_CONVERT 为什么必须配成成对路径前缀这个参数不是做字符串替换,而是按「主库路径前缀 → 备库路径前缀」做精确匹配替换。一旦主库数据文件路径不以你写的前缀开头,db_file_name_convert 就完全不生效,备库会直接报 ora-01119 或 ora-19504 ------ 文件创建失败。常见错误是只写目录名(比如 '/u01/oradata/prod', '/u02/oradata/std'),但主库实际路径是 /u01/oradata/prod/users01.dbf,而备库想放到 /u02/oradata/std/prod/users01.dbf。这时必须把前缀写全:前者得是 '/u01/oradata/prod/', '/u02/oradata/std/prod/',末尾斜杠不能少。必须两端都带结尾斜杠,否则可能只匹配到部分路径(比如把 /u01/oradata 错误匹配进 /u01/oradata_bak)大小写敏感,Linux 下 PROD 和 prod 视为不同前缀不支持通配符、正则或模糊匹配,只认字面量前缀多个映射对用逗号分隔,顺序无关,但建议按路径层级从长到短排列,避免短前缀提前截断主备库目录结构差异大时,怎么避免 DB_FILE_NAME_CONVERT 写崩如果主库用 /u01/oradata/dbname/,备库用 /oradata/standby/datafiles/,硬凑前缀映射容易漏文件或错映射。这时候更稳的方式是:先在备库用 ALTER SYSTEM SET STANDBY_FILE_MANAGEMENT=MANUAL,再靠 CREATE TEMPFILE / ALTER DATABASE CREATE DATAFILE 手动建;等同步稳定后,再切回 AUTO 并补全 DB_FILE_NAME_CONVERT。临时表空间文件不会被 DB_FILE_NAME_CONVERT 自动处理,必须单独用 ALTER DATABASE ADD TEMPFILE 指定备库路径在线日志路径由 LOG_FILE_NAME_CONVERT 控制,和 DB_FILE_NAME_CONVERT 互不干扰,别混在一起配如果主库用了 OMF(Oracle Managed Files),备库又没开 DB_CREATE_FILE_DEST,那 DB_FILE_NAME_CONVERT 无效,必须关 OMF 或统一配置 DB_CREATE_FILE_DESTALTER SYSTEM SET 后不生效?检查这三处硬性条件DB_FILE_NAME_CONVERT 是静态参数,但只在备库处于 MOUNT 状态且未启动 Redo Apply 时才被读取。一旦已启库或已在恢复中,改了也白改。必须在备库 SHUTDOWN IMMEDIATE 后,用 STARTUP MOUNT 加载,再 ALTER SYSTEM SET ... SCOPE=SPFILE修改后要重启备库(不是只 ALTER SYSTEM),否则新值不进内存也不影响后续文件创建确认 STANDBY_FILE_MANAGEMENT 是 AUTO,否则参数根本不会触发自动映射逻辑验证转换是否真起作用的最快方式别等主库加数据文件再看备库报错------直接在主库执行:ALTER DATABASE ADD DATAFILE SIZE 10M,然后立刻查备库:SELECT NAME FROM V$DATAFILE WHERE NAME LIKE '%/u02%'。如果返回空,说明映射失败;如果返回新文件且路径符合预期,说明生效。 Zeemo AI 一款专业的视频字幕制作和视频处理工具

相关推荐
weixin_459753942 分钟前
c++如何利用filesystem--relative计算两个文件之间的相对路径【详解】
jvm·数据库·python
阿福聊编程10 分钟前
Data-Analysis-Agent:用自然语言查数据库的开源 AI 数据分析工具
数据库·人工智能
jekc86810 分钟前
金蝶云星空调用第三方接口
开发语言·python
行业研究员14 分钟前
2026 Agent Memory主流方案能力解析与落地选型
大数据·数据库·agent记忆
才兄说15 分钟前
机器人二次开发机器狗巡检?自动生成巡检日志
python
专注VB编程开发20年16 分钟前
json和python元组,列表,字典对比
开发语言·python·json·php
m0_5967490916 分钟前
Golang怎么实现队列数据结构_Golang如何用切片实现先进先出的队列【方法】
jvm·数据库·python
梦想不只是梦与想21 分钟前
python 中的进制
python·进制转换
qq_2975746722 分钟前
MySQL核心技术实战系列(第二篇):MySQL核心基础:库与表的增删改查(CRUD)实战
数据库·mysql
knight_9___22 分钟前
大模型project面试3
人工智能·python·语言模型·面试·大模型·agent