当前位置: 首页 > article >正文

测试库与生产库怎么仅同步新增增量数据_无损发布与更新方案

pg_dump --inserts ON CONFLICT DO NOTHING 可安全实现增量同步先用 --inserts 导出新增数据再用 sed 替换为 INSERT ... ON CONFLICT DO NOTHING依赖唯一约束跳过重复避免误更新或主键冲突。如何用 pg_dump --inserts --on-conflict-do-nothing 实现 PostgreSQL 增量同步增量同步不是靠“全量比对”而是靠业务主键或时间戳字段识别新增。postgresql 本身不提供内置增量复制除非用逻辑复制槽但开发侧可控场景下最轻量、无损的方式是导出新增记录再安全插入。常见错误现象INSERT INTO ... SELECT 直接跨库执行遇到重复主键就报 duplicate key violates unique constraint或者用 ON CONFLICT DO UPDATE 误改老数据——这违反“仅同步新增”的前提。必须确认目标表有唯一约束如 id 或 (tenant_id, event_id)否则 ON CONFLICT 无意义导出时加 --inserts不用 --column-inserts后者性能差且易因列顺序错位失败生成的 SQL 中把 INSERT 替换为 INSERT ... ON CONFLICT DO NOTHING一行命令即可sed s/INSERT INTO/INSERT INTO ON CONFLICT DO NOTHING/g dump.sql safe_insert.sql若源库用的是 serial 或 identity确保目标库同字段未设 DEFAULT 冲突否则插入可能跳过值或报错MySQL 的 REPLACE INTO 和 INSERT IGNORE 怎么选REPLACE INTO 是先删后插会触发 DELETE INSERT 两个事件自增 ID 可能跳变、外键关联记录若没设 ON DELETE CASCADE 会失败INSERT IGNORE 才真正符合“仅新增”语义——冲突就跳过不扰动存量。使用场景ETL 脚本跑定时任务同步日志表、订单明细等只追加不修改的业务表。务必确认目标表有 UNIQUE KEY 或 PRIMARY KEY否则 IGNORE 不生效INSERT IGNORE 对 NOT NULL 字段缺失值报错不是忽略得提前清洗数据避免在大事务中混用MySQL 的 INSERT IGNORE 在事务里遇到冲突仍会占用自增 ID长期运行可能导致 ID 浪费替代方案用 INSERT ... SELECT ... WHERE NOT EXISTS更明确但需注意子查询不能引用目标表会报 You cant specify target table for update in FROM clause为什么不能直接用 mysqldump --where 或 pg_dump -t 做增量因为 --where 是静态条件比如 --wherecreated_at 2024-06-01它依赖应用层严格保证 created_at 写入即准确、无回填、无时区错乱——现实中常有延迟写入、批量补数、跨时区服务混用等情况导致漏数据或重复。性能影响WHERE 条件若没走索引mysqldump 会全表扫描pg_dump -t 单表导出不带条件根本不是增量。正确做法是维护一个 sync_cursor 表存每张表最后同步的 id 或 updated_at每次取 WHERE id ?并用 SELECT MAX(id) 更新游标游标更新必须和插入在同一个事务里完成MySQL 支持PG 需 BEGIN; INSERT ...; UPDATE cursor; COMMIT;否则断点续传不可靠别信 SHOW MASTER STATUS 或 pg_logical_slot_get_changes ——它们面向 DBA 级复制开发侧接入成本高、权限要求严、容易积压上线前最容易被忽略的三个检查点无损发布的“无损”不是指技术上没报错而是指业务上没感知、数据上没偏差。这三个点一漏可能凌晨两点被叫醒查数据对不齐。目标库的字符集和排序规则COLLATION是否和源库一致尤其 MySQL 中 utf8mb4_0900_as_cs 和 utf8mb4_general_ci 对大小写敏感性不同会导致 ON DUPLICATE KEY 判定结果不一致同步脚本是否校验了行数导出后、导入前、导入后分别 SELECT COUNT(*)三者不等就得停——别依赖“看起来没报错”有没有关掉目标库的外键检查SET FOREIGN_KEY_CHECKS0开着的话插入顺序不对会失败但关了之后得自己确保引用完整性否则后续查关联数据就空了

相关文章:

测试库与生产库怎么仅同步新增增量数据_无损发布与更新方案

pg_dump --inserts ON CONFLICT DO NOTHING 可安全实现增量同步:先用 --inserts 导出新增数据,再用 sed 替换为 INSERT ... ON CONFLICT DO NOTHING,依赖唯一约束跳过重复,避免误更新或主键冲突。如何用 pg_dump --inserts --…...

Agenus 指定 BAP Pharma 为 BOT+BAL 准入项目全球独家合作伙伴

• 本次合作将通过法国政府报销的 Autorisation d’Accs Compassionnel(AAC),以及部分国家的付费指定患者用药项目(Named Patient Programs,NPP),为患者及时获取 botensilimab 联合 balstilimab…...

别再死记硬背了!用生活中的例子和动画,5分钟搞懂杨氏双缝干涉到底在说什么

用生活中的波纹和光影游戏,轻松理解杨氏双缝干涉 想象一下,当你同时往平静的池塘里扔进两块小石子,水面上会形成两圈向外扩散的波纹。当这两组波纹相遇时,有些地方的水面起伏特别剧烈,有些地方却异常平静——这就是波动…...

DownKyi终极指南:3步掌握B站视频高效下载与管理

DownKyi终极指南:3步掌握B站视频高效下载与管理 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等)…...

深度学习归一化技术:从原理到TensorFlow实践

1. 深度学习中的归一化技术解析在深度学习的实践中,数据预处理和模型优化是两个永恒的话题。当我们第一次接触机器学习时,往往被告知需要对输入数据进行标准化处理。但很少有人深入解释:为什么这种处理能提升模型性能?以及这种思想…...

机器学习项目实战:避免十大常见陷阱的关键策略

1. 机器学习项目失败的十大隐形陷阱在过去的五年里,我参与过47个不同规模的机器学习项目,其中有12个最终没能投入生产环境。最令人沮丧的是,这些失败往往不是因为技术难题,而是源于一些看似简单却极易被忽视的错误。今天我要分享的…...

裸金属服务器部署RKE2 Kubernetes集群构建MLOps平台实战

1. 项目概述:基于裸金属环境的RKE2 Kubernetes集群MLOps平台构建在当今数据驱动的业务环境中,机器学习模型的工业化部署已成为企业核心竞争力的关键组成部分。本文将详细记录我们在裸金属服务器上,基于Rancher RKE2 Kubernetes发行版构建完整…...

别再死记硬背了!用Wireshark抓包实战,5分钟搞懂UDS网络层(ISO-15765)的SF/FF/CF/FC帧

用Wireshark解密UDS网络层:从抓包实战理解ISO-15765帧结构 当你第一次面对UDS诊断协议的网络层时,那些抽象的概念和术语可能会让你感到无从下手。单帧(SF)、首帧(FF)、连续帧(CF)、流控帧(FC)这些名词在文档中反复出现,但纸上得来终觉浅。作为…...

SAP FICO顾问实战:手把手教你激活GB01字段并搞定OBBH替代(附完整代码)

SAP FICO实战:解锁GB01隐藏字段与OBBH替代配置全流程 当标准SAP功能无法满足业务需求时,资深顾问往往需要深入系统底层进行定制化增强。本文将带您完整走通从发现限制到解决问题的全流程,重点解决两个典型场景:利润中心传递和开票…...

Streamlit Secrets实战:为你的Nanbeige聊天室加把安全锁

Streamlit Secrets实战:为你的Nanbeige聊天室加把安全锁 1. 引言:当二次元美学遇上安全挑战 如果你正在使用那个拥有《蔚蓝档案》MomoTalk风格的Nanbeige 4.1-3B Streamlit WebUI,你一定已经沉醉于它极简的聊天气泡设计和丝滑的对话体验。这…...

3分钟学会用开源工具VideoSrt:视频字幕自动生成的终极解决方案

3分钟学会用开源工具VideoSrt:视频字幕自动生成的终极解决方案 【免费下载链接】video-srt-windows 这是一个可以识别视频语音自动生成字幕SRT文件的开源 Windows-GUI 软件工具。 项目地址: https://gitcode.com/gh_mirrors/vi/video-srt-windows 你是否曾花…...

60美元AI眼镜TikTok爆卖160万!中国品牌正在改写智能穿戴格局

在跨境电商的世界里,真正的爆款往往不是那些堆砌高端配置的“黑科技”,而是能够用极致性价比让前沿科技走进普通人生活的产品。最近,TikTok美区数码产品榜单上出现了一匹令人瞩目的黑马——一款售价仅60美元左右的AI智能眼镜,在一…...

保姆级教程:用MQTT.fx 1.7.1模拟设备,5分钟搞定OneNET MQTT协议接入

零基础极速上手:用MQTT.fx实现OneNET设备接入全流程指南 第一次接触物联网平台接入时,那种面对专业术语和复杂文档的手足无措感我至今记忆犹新。本文将以最直观的方式,带您用MQTT.fx工具在5分钟内完成OneNET平台的设备模拟接入全流程。不同于…...

Asian Beauty Z-Image Turbo部署教程:Windows WSL2环境下CUDA兼容配置

Asian Beauty Z-Image Turbo部署教程:Windows WSL2环境下CUDA兼容配置 想在自己的电脑上生成独具东方韵味的人像写真,又担心在线工具泄露隐私?今天,我们就来手把手教你,如何在Windows系统上,通过WSL2&…...

螺杆真空泵看似小众,化工行业应用却无处不在

螺杆真空泵深度分析:化工行业无处不在的核心设备,如何选对靠谱供应商?“选对螺杆真空泵,化工生产效率提升30%的关键不在价格,而在这4个核心维度”——化工行业中,螺杆真空泵是处理腐蚀性气体、保障工艺真空…...

不止于画图:用GMT6脚本批量处理地形数据并添加自定义站点标记

不止于画图:用GMT6脚本批量处理地形数据并添加自定义站点标记 当监测站点数量从个位数跃升到上百个时,手动逐个标注坐标、调整图例的工作量会呈指数级增长。去年参与某地震监测项目时,我曾亲眼见证团队花费整整三天时间反复修改80多个台站的定…...

NoFences终极桌面分区指南:免费打造高效工作空间

NoFences终极桌面分区指南:免费打造高效工作空间 【免费下载链接】NoFences 🚧 Open Source Stardock Fences alternative 项目地址: https://gitcode.com/gh_mirrors/no/NoFences 你是否每天在混乱的桌面图标中寻找文件,浪费宝贵时间…...

Janus-Pro-7B效果展示:同一张建筑图纸→生成技术描述+施工建议文本

Janus-Pro-7B效果展示:同一张建筑图纸→生成技术描述施工建议文本 1. 模型效果惊艳展示 Janus-Pro-7B作为新一代统一多模态模型,在建筑图纸理解和技术文本生成方面展现出了令人印象深刻的能力。通过一张普通的建筑平面图,这个模型不仅能准确…...

【SpringBoot3.x 实战】Jakarta依赖冲突排查与精准引入指南

1. 从报错到真相:Jakarta依赖为何突然失效? 那天我正在将一个老项目迁移到SpringBoot3.x和Java17环境,编译时突然蹦出"程序包jakarta.annotation不存在"的红色警告。明明上周新建的SpringBoot3.x项目运行得好好的,怎么同…...

深度学习卷积层核心原理与应用实践

1. 卷积层基础概念解析卷积层(Convolutional Layer)是深度学习中处理网格状数据(如图像、音频、视频)的核心组件。我第一次接触这个概念是在2014年参加计算机视觉会议时,当时AlexNet刚掀起深度学习革命不久。与全连接层…...

Fluent材料物性设置避坑指南:温度单位搞错?系数顺序反了?一次讲清

Fluent材料物性设置避坑指南:温度单位搞错?系数顺序反了?一次讲清 在CFD仿真中,材料物性参数的准确设置往往是决定模拟成败的关键细节。许多工程师花费大量时间调试网格和边界条件,却忽略了物性设置这个"隐形杀手…...

数据科学与AI入门指南:从基础到实战

1. 数据科学与AI职业入门指南我刚入行数据科学时,最头疼的就是不知道从哪开始。网上资料太多太杂,各种技术名词满天飞,Python、机器学习、深度学习、TensorFlow...到底该先学哪个?这份手册就是帮你理清思路的实战指南,…...

护照扫描仪在金融行业的应用简述

金融行业适用场景:银行网点、外汇兑换点、跨境支付机构、证券公司、保险公司核心应用: 银行涉外开户:外籍客户办理银行卡时,快速读取护照信息并完成KYC核验外币兑换:扫描护照自动采集身份信息,辅助完成兑换…...

手机芯片里的‘内存’和‘闪存’到底啥区别?LPDDR5和UFS 3.1怎么选才不亏?

手机芯片里的‘内存’和‘闪存’到底啥区别?LPDDR5和UFS 3.1怎么选才不亏? 每次打开电商平台选购手机,总会被"8GB128GB"、"12GB256GB"这样的参数组合搞得一头雾水——前面的数字和后面的数字到底谁决定了手机流畅度&…...

Prompt 缓存有没有用?从治理视角看,关键还是缓存层放得对不对

很多系统一开始做 Prompt 缓存,出发点都很直接:希望少发一些重复内容,把调用成本压下来。 这个方向没有问题,但如果系统已经进入正式业务,缓存的价值通常不会只停留在“省一点 token”。 为什么 Prompt 缓存最后会变成…...

YOLO26如何涨点系列篇(NEU-DET缺陷检测) | CVPR2026 FAAFusion 解决Neck跨尺度方向冲突,实现涨点1.2%

💡💡💡原始YOLO网络的问题点: 方向信息丢失:YOLO的neck通过上采样(nn.Upsample)和拼接(Concat)融合多尺度特征,但高层特征(语义强)方…...

40G ZR4光模块:长距互联的优选方案

数字经济飞速发展,5G骨干网建设、跨城数据中心互联、企业广域组网等场景持续扩容,对光传输提出了“高速率、长距离、高性价比”的核心需求。40G ZR4光模块凭借80km超远距传输能力,精准衔接10G与100G传输体系,成为长距互联的高性价…...

多层板PCBA回流焊接中的热应力控制方法

在多层板PCBA的加工中,回流焊接是确保焊点质量和元件可靠性的核心环节。然而,由于多层板的复杂结构和材料特性,回流焊接过程中产生的热应力可能引发翘曲、焊点裂纹等问题,直接影响产品的良率和使用寿命。因此,掌握有效…...

终极免费AMD Ryzen调试工具:如何深度掌控处理器性能?

终极免费AMD Ryzen调试工具:如何深度掌控处理器性能? 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: …...

本地化增强方案:开源工具实现WeMod专业功能解锁的技术实践

本地化增强方案:开源工具实现WeMod专业功能解锁的技术实践 【免费下载链接】Wand-Enhancer Advanced UX and interoperability extension for Wand (WeMod) app 项目地址: https://gitcode.com/gh_mirrors/we/Wand-Enhancer 在游戏辅助工具生态中&#xff0c…...