两千张表,三百万病人:一场没有”撤销”按钮的迁移

“如果现在停止迁移,数据会不一致,永远回不去了。”

凌晨两点,XX医院数据中心。老周盯着屏幕上的进度条,手在发抖。

迁移进度:87%。

总数据量:2.3 TB。

Tables 数量:2176张。

涉及的核心业务:三百万病人的历史病历、五年门诊记录、三年住院档案。

如果失败,后果不堪设想。

但迁移已经开始,没有”撤销”按钮。

1. 为什么这个迁移这么难?

这次迁移,不是简单的”升版本”,而是从旧架构V3.0,迁移到新架构V4.0

两个架构的区别:

– V3.0是单体数据库,所有业务数据在一张库

– V4.0是微服务架构,业务数据分库分表:门诊库、住院库、药房库、财务库、病历库…

以前的迁移,只需要在同一个数据库里改表结构,数据不动——这次,要把数据从”一张大饼”拆成”五块小饼”,还要保证每块小饼都能重新拼回原来的样子(如果失败回滚)。

难点:

1. 数据拆分逻辑复杂:比如门诊缴费记录,原来在payment表里,现在要拆成paymentheader(支付头)和paymentitems(支付明细);还要关联到outpatient_visit(门诊就诊)表。拆分规则涉及六张表。

2. 历史数据质量堪忧:三年积累的数据,有很多”脏数据”——重复记录、缺失字段、编码错误(比如性别填了”未知”),这些在V3.0时代都容忍了,但V4.0的schema有严格约束,脏数据会导入失败。

3. 没有”试错”机会:迁移窗口只有两天(五一假期门诊量少)。两次迁移机会——第一次失败,第二次必须在12小时内完成,否则影响初二开诊。如果两次都失败,就只好延期,等着杨院长问责。

老周带人准备了三个月:

– 写迁移工具(自己开发的data-migrator

– 清洗脏数据脚本

– 回滚方案

– 全量演练三次,每次都发现问题,每次都改,第三次演练才成功

但演练再成功,也不是真迁移。

2. 迁移开始后,第一个坑:脏数据

晚上八点,迁移开始。

前两个小时顺利:系统库、用户表、权限表…都是一马平川。

十点,开始迁移核心业务数据。

payment表开始迁移,1%…2%…

突然,报错。

“`
ERROR: Violation of NOT NULL constraint: column ‘patient_id’ cannot be null
“`

日志里指明,有一条记录的patient_id是NULL。

这是脏数据。

老周让小吴排查:SELECT COUNT(*) FROM payment WHERE patient_id IS NULL

结果:73条。

这些记录,都是V3.0时代的老数据,可能是创建记录时系统bug,patient_id没填。

小吴说:”跳过这73条吧,不影响整体。”

“不行。”老周说,”如果跳过,对账的时候会发现门诊对不上。而且,如果这73条都是大额缴费,财务损失谁负责?”

他们做了个决定:现场清洗

写了一条UPDATE语句,试图从其他表关联补全patientid。但关联发现,这73条记录对应的visitid也缺失,无法追溯到具体是哪次就诊。

死循环。

“只能手工造一个patient_id了。”小吴说,”造一个虚拟患者,把这73条付款挂到他名下。等迁移完成,我们在新系统里加一个’未知患者’账户,把这些数据放进去,后续再处理。”

老周犹豫。虚拟数据虽然能过关,但数据准确性打了折扣。

“有没有其他办法?”

“或者,我们暂停迁移,先回滚,把脏数据彻底清理完再迁?”

回滚意味着放弃这次窗口,五一假期只剩一天了,不够。

时间不等人。

老周咬了咬牙:”现场清洗——把有问题的数据,标上’待处理’标签,迁过去后我们在新系统里专门建一个’脏数据沙箱’,隔离存放。”

这是妥协,但迁移不能停。

3. 第二个坑:数据不一致

凌晨一点,进度到63%。

小吴发现一个问题:visitdate字段,在V3.0里是datetime类型,V4.0里拆分成visitdate(日期)和visit_time(时间)。迁移工具把小吴写得有bug:在拆分日期和时间时,时区处理错了。

V3.0存储的是本地时间(东八区),迁移工具当成UTC时间处理,减了8小时。

结果:所有就诊时间的visit_time,都比实际时间晚8小时。

比如一次早上8点的就诊,迁过去后变成了凌晨0点。

“天呐…”小吴脸白了。

老周也傻了。

这不是小问题。时间错误,会影响排班、统计、甚至医保结算(医保要求精确到小时)。

“修复这个bug,但已经迁过去的数据怎么处理?”

更可怕的是:已经迁了63%的数据,现在发现一个重大bug,是继续迁(错上加错),还是回滚?

继续,所有数据都错,无法挽回。

回滚,63%的数据要清理,重新迁,时间不够。

老周深吸一口气:”调出这个bug的影响范围数据。我们现场修复——迁过去的63%,我们另写一个’修正脚本’,把时间加8小时。”

小吴心算了一下:数据量800万条,修正脚本跑一遍要2小时。

“时间够吗?”

“不够也要够。”老周说。

4. “修正脚本”成为赛跑

老周和团队吃了两片咖啡因,开始写修正脚本。

脚本逻辑很简单:

“`sql
UPDATE outpatient_visits
SET visit_time = DATEADD(hour, 8, visit_time)
WHERE visit_time IS NOT NULL
“`

但要跑800万行,必须在2小时内完成,否则夜深了,医院的业务开始恢复,没机会再改。

他们优化:

1. 分批更新,每次10万行,commit 后继续

2. 加索引:在visit_time上建临时索引,加速 update

3. 关掉binlog,减少IO

4. 调大innodbbufferpool_size,确保数据在内存里

脚本跑起来,每分钟更新12万行。

一小时,600万。

凌晨三点,修正完成。

迁移继续。

5. 最后一个坑:外键约束冲突

早上七点,进度97%。

只剩最后一批数据迁移:prescription(处方)表。

报错:

“`
ERROR: Cannot add or update a child row: a foreign key constraint fails (`prescription` constraint `fk_prescription_visit`)
“`

意思是:有一条prescription记录,引用的visitid,在outpatientvisit表里找不到。

脏数据 again。

但这次很奇怪:前96%的数据都关联成功,为什么最后3%会丢?

小吴排查:最后这批数据,是2024年12月31日跨年的那批。那几天系统做了一次数据归档——把半年前的记录移到历史库。

但归档工具可能有bug,把某些visit_id漏了。

“跳过吧,”小吴说,”就几条处方,影响不大。”

“不行。”老周说,”处方是核心业务,漏一条,病用药记录就不全。而且,这是系统性问题的体现——如果这里漏了,其他地方呢?”

他们决定:现场补数据

方法:从旧库(V3.0)里,把这批visit_id对应的记录,手动补出来,再导入新库。

旧库还没关,可以查。

但旧库是生产环境,不能直接操作。他们只能查,不能改。

查询:SELECT * FROM outpatientvisit WHERE visitid IN (xxx, yyy, zzz)

发现这三条visitid对应的记录,已经被归档到outpatientvisit_history表了。

迁移工具没考虑到这种情况——只迁了主表,没迁历史表,导致引用断裂。

小吴把这些历史记录也迁过去,但迁到outpatient_visit主表(违反了业务逻辑,历史记录不应该混在主表里)。

“标记为历史记录。”老周说。

6. 100%完成后,还有验证

早上八点,迁移工具显示:100%。

所有人松了一口气。

但老周没放松:”迁移完成,不算完成;数据验证通过,才算完成。”

他们有一套验证流程:

1. 行数对比:每张表的记录数,新库 vs 旧库,差异率<0.1%

2. 总和校验:对金额、数量等关键字段,做SUM对比,应该相等

3. 样本抽查:随机抽取1000条记录,逐字段对比,应该一致

4. 业务逻辑验证:跑一遍核心业务流程(挂号→开处方→缴费),结果应该一致

前三个通过,第四个出问题。

模拟一次门诊全流程:挂一个号,开三个药,缴费。

在V4.0里,挂号的visitid,和处方的visitid,对不上。

又一轮排查发现:visit表的id字段是自增的,迁移过程中,新库的自增起点没设置对,导致新生成的ID和旧的不一样。但prescription表里的visit_id是直接迁过来的(旧的ID值),而新挂号的ID是新产生的(新的自增值),两者当然对不上。

“这是一个’活数据’问题,不是迁移问题。”小吴说。

老周明白了:迁移只迁了历史数据,但迁移完成后,新产生的数据用的ID和旧数据不连续。这会影响对账、追溯等需要全局ID唯一性的场景。

解决的方案:重置自增ID的起点,让它从旧库的最大ID+1开始。

但问题是:迁移后已经产生了一条新挂号记录(验证用的),ID是1。重置起点后,这条记录的ID会和后面的冲突。

只能删除这条验证数据,重置ID,再重新验证一次。

折腾到中午十二点,全部通过。

7. 事后反思:我们做对了什么?

这次迁移后,老周写了长篇复盘。

他的结论:

1. “现场清洗”是必须的能力

– 不要指望数据100%干净再迁

– 要能在迁移过程中,实时发现脏数据,实时处理(跳过、修正、隔离)

2. 修正脚本应该提前准备好

– 不是所有bug都能在迁移前发现

– 为每一类可能的数据问题,提前写好”修正脚本模板”,迁移时填参数就能跑

3. 验证必须自动化

– 人工抽查不够,要有程序自动跑完整的数据验证流程

– 验证通过率应该>99.99%

4. 要有”回滚点”概念

– 每完成一个业务单元(如门诊库),就做一个”回滚点”

– 后面的阶段失败,可以回滚到这个点,而不是全部重来

5. “迁移”不只是”搬数据”

– 还包括:ID生成策略、自增主键连续性、时间戳时区、字符集转换…

– 任何细节出错,都会导致业务逻辑错误

互动话题

你经历过最复杂的数据迁移是什么?有什么经验教训?

> 基于真实医院场景改编,人物均为化名


立即免费试用门诊系统https://app.kmhis.com/
International Versionhttps://app.kmhis.com/multi/
了解软佳门诊管理系统详情https://www.kmhis.com/outpatient-management-system.html


扫码预约

手机扫码试用患者预约。请勿输入个人真实信息(点击图片可查看原图)

支持8种语言:简体中文、繁体中文、香港中文、English、藏文、泰文、老挝语、越南语


说真的。这类问题我见过太多了。每次看到医院同事为选型头疼。我就想,要是早点有人把这些经验分享出来就好了。毕竟。选择不对。后面全是麻烦。选择对了。省心省力。还能提升整个机构的运行效率。希望这篇能帮到正在纠结的你。

你如果有具体需求。也可以去 www.kmhis.com 看看。那里有更详细的技术方案和案例。

合同里那一条”最终解释权”差点毁掉合作

XX医院的合同谈判进入最后一轮。会议室里,长桌两侧分别坐着医院采购小组的七个人和昆明软佳的谈判团队。赵主任作为信息科负责人,拿着一份打印好的合同草案,逐条审阅。

翻了十几页,他的目光停留在第15条:

第15条 最终解释权

本合同的一切解释权归乙方(软佳公司)所有。如有争议,由乙方单方面解释并处理。

赵主任抬起头,脸色有点不好看:”你们能不能把这条删掉?”

软佳的区域经理老王愣了愣:”赵主任,这是我们的标准条款,所有医院都签,没出过问题。”

“但我不想签一个对自己不利的条款。”赵主任的声音平静但坚定,”万一以后有争议,我们连说话的地方都没有。这就像是 belts and braces,法律上可能站不住脚,但心理上让人不舒服。”

医院财务科王科长也附和:”我们医院是大单位,不能签这种显失公平的条款。如果连解释权都在对方手里,我们管理层怎么向院长交代?”

老王急忙解释:”赵主任,这条只是形式。真要有争议,我们肯定会协商解决,不会真的’单方面解释’就完事。而且这是我们的标准合同,如果要改,需要总部特批,流程很长。”

“那我们就按标准流程等,”赵主任把合同合上,”要么改,要么我们考虑重新招标。”

谈判气氛瞬间降至冰点。医院方面没人说话,软佳团队面面相觑。他们没想到,这么一条看似”例行公事”的条款,会成为签约的拦路虎。

1. 一条”标准条款”为什么重要?

当天晚上,老王回到酒店,给总部发邮件请示。总部法务回复:”标准条款不能改,否则其他客户会效仿,我们的统一合同体系会被打乱。”

老王苦笑。他知道赵主任的担心不是没有道理。很多供应商在合同里藏了”霸王条款”,比如最终解释权、单方面变更权、免责条款等,乍看没什么,一旦出纠纷就处于弱势。医院这种单位,最怕的就是”签完合同就被动了”。

小张——软佳的客户经理——也在思考。他回想赵主任那天的表情:不是咄咄逼人,而是失望。赵主任其实很重视这次合作,他认可软佳的技术方案和服务,但这条款让他觉得”不够尊重”。

小张意识到:合同条款不仅是法律文件,也是关系文件。 如果在签合同前就让客户感到不平等,后面合作再好,心里也会有根刺。

但总部不同意改,怎么办?

2. 改变的思路:用价值交换

第二天,小张约赵主任单独喝茶,没有其他人在场。

“赵主任,关于那条解释权,我想听听您的真实想法——除了’不公平’,您最担心的是什么?”

赵主任沉默片刻,说:”我们医院这几年信息化投入很大,HIS系统是核心。我们选择供应商,不只是买软件,更是找长期合作伙伴。如果合同写’解释权归对方’,意味着在系统升级、功能变更、纠纷处理上,我们要么接受要么终止,没有商量余地。这种感觉,就像把自己的命交到别人手里。”

小张点点头:”我理解。其实我们内部也觉得这条不太合适,但它确实是标准条款。我在想,有没有折中方案——既能照顾贵院的感受,又不让我们违反公司规定。”

“什么方案?”

“比如,我们可以把这一条改成:’双方共同解释,如有分歧通过友好协商解决;协商不成的,提交XX仲裁委员会仲裁。’这样既不是医院单方面说了算,也不是我们单方面说了算,而是共同管理。”

赵主任眉毛扬了扬:”继续。”

“同时,”小张顿了顿,”如果贵院同意删除原条款,我们可以在付款条件上做一些让步——比如首付比例从30%提高到50%,尾款由一年缩短到六个月。这样我们提前收到的钱多一些,风险降低,总部那边我也好交代。”

赵主任沉思良久。

3. 内部角力:总部的底线

小张回到公司,把赵主任的反应和自己的想法汇报给总部。

总部合同法务 initially 反对:”删除最后解释权可以,但必须让客户在其他方面补偿我们。否则每家企业都来砍条款,我们的合同就乱套了。”

财务也参与了讨论:”提前收款是好事,但首付提高到50%,有些客户可能现金流紧张,反而影响签约。不过XX医院是三甲,付款没问题。”

经过两天的会议,总部给出最终方案:

– 可以删除”最终解释权”条款。

– 替换为”双方共同解释,协商不成则仲裁”。

– 作为交换,首付款从30%提升到50%,尾款从12个月缩短至6个月。

– 其他条款保持不变。

老王看到方案后,对小张说:”你小子运气好,赵主任如果不同意,这单就黄了。”

小张心里清楚:这不是运气,而是找到了对方真正的痛点——赵主任不在乎多付点钱,他在乎的是合作的关系是否平等、透明。医院不缺钱,缺的是安全感。

4. 成交:一场共赢的谈判

小张再次来到医院,把两个选项放在赵主任面前:

选项A:保持原合同,不删除”最终解释权”,付款条件为首付30%,尾款12个月。

选项B:删除”最终解释权”,替换为共同解释+仲裁条款;付款条件为首付50%,尾款6个月。

赵主任盯着两个选项看了几分钟,抬起头:”我选B。”

“不加考虑?”

“钱多付一点没关系,关键是我们要的是平等合作。你们愿意删掉那个条款,说明把我们当真正的伙伴,不是甲方乙方。我信任你们。”

小张心里一块石头落地。他补充道:”赵主任,我保证,这个协商过程本身就会成为我们合作的基石——我们学会了坦诚沟通,互相倾听。”

一周后,合同正式签署。双方代表握手时,赵主任笑着说:”希望这是真正长期合作的开始。”

5. 三年后:那条条款的遗产

三年过去,HIS系统运行稳定。期间有过两次大的升级,每次软佳都提前一个月通知,并提供迁移工具。医院也追加了两个模块:移动查房和急诊分诊。

在一次升级复盘会上,赵主任对软佳的技术总监说:”还记得当年那条’最终解释权’吗?当时差点因为这个条款谈崩。”

技术总监笑了:”记得,我们内部还争论过该不该坚持。”

“现在我明白了一个道理:合同不仅是法律文件,更是关系文件。 你们愿意为删掉那条条款调整付款条件,说明你们在乎长期合作,不是一锤子买卖。”

赵主任接着说:”这三年,我们遇到问题随时联系,你们响应很快;有需求提出来,你们认真评估。这种无障碍的沟通,比任何完美合同都重要。如果我们当初因为那条僵硬的条款不欢而散,今天就不会有这种信任。”

软佳的区域经理接话:”其实那次谈判,对我们内部也是一种文化塑造。后来我们修改了标准合同模板,把所有’单方面解释’、’单方面变更’类条款都改成了协商机制。因为赵主任让我们看到:客户真正在意的是什么。”

6. 谈判的四个法则

事后,小张总结了这次谈判的四个法则:

1. 区分核心与非核心

“最终解释权”对软佳来说是非核心条款——删掉不会影响核心权利,但对客户来说却是心理核心——它代表尊重和平等。在非核心上让步,换取核心利益(合同能签、关系好、付款快),是划算的。

2. 创造互惠的机会

客户让一步,你也让一步。谈判不是零和游戏,而是价值交换。赵主任接受了更高的首付,软佳删掉了条款,双方都觉得”我得到了我想要的”。

3. 倾听比说服更重要

小张没有一上来就说”我们标准不能改”,而是问”您最担心的是什么”。了解到赵主任真正在意的是”被尊重的感觉”后,方案就好设计了。

4. 一次不好的谈判,可能毁掉十年的关系

如果当时软佳坚持原条款,哪怕最终用压力让医院签了字,后续合作也会带着疙瘩。而一次坦诚的让步,换来三年甚至更长时间的顺畅合作。

7. 法律与关系:平衡的艺术

很多法务人员倾向于把合同做得”滴水不漏”,处处为供应商设置有利条款。但从实战来看,过于强势的合同反而会让客户心存芥蒂,影响长期合作。

软佳后来形成了”合同谈判三原则”:

必须守住的底线:知识产权归属、保密责任、核心服务内容。

可以协商的非核心条款:解释权、付款细节、违约责任上限、通知方式等。

坚决不出现的霸王条款:单方变更权、无限责任转嫁、显失公平的免责。

“解释权”这件事成了公司内部的一个经典案例。新销售培训时,老张(现在的销售总监)常说:”别以为合同签下来就赢了。签合同只是开始,后面的合作长着呢。如果为了签合同而埋下雷,爆炸的时候炸的是自己。”

8. 从一次谈判到文化改变

这次经历还带来另一个变化:软佳在内部推行了”灵活协商机制”。对于标准合同,允许区域经理在不涉及核心利益的前提下,与客户协商调整条款,但必须记录原因并报备。公司发现,这种灵活性反而增强了客户的信任——因为他们感受到供应商愿意倾听、愿意合作。

有一次,一个客户提出修改”服务等级协议(SLA)”中的响应时间,把4小时改为2小时。软佳评估后认为技术上可行,便同意了。客户受宠若惊:”你们真改?”

“既然您提了,说明您在意,我们在能力范围内满足。”小张回答。

那个客户后来成了公司的”明星客户”,不仅续约率高,还介绍了三家新客户。

9. 关系的开始,往往是一个小让步

赵主任在三年后的今天,还会在行业会议上分享这个故事:”选择供应商,不光看技术和价格,更看合同有没有诚意。如果合同里全是’最终解释权归乙方’这类条款,再便宜我也不用。”

反过来,软佳的销售人员在面对新客户时,也会主动提起:”我们愿意把’解释权’改成协商机制,因为我们追求长期合作,不是一锤子买卖。”

一个小小的条款,差点毁掉一单合同;而一个 willingness to compromise,反而赢得了十年的伙伴。

互动话题

你们在合同谈判中,最常卡在哪一条?有没有因为坚持条款而失去客户,或者因为让步而赢得长期信任的经历?欢迎分享你们的”合同谈判故事”。

> 基于真实医院场景改编,人物均为化名


立即免费试用门诊系统https://app.kmhis.com/
International Versionhttps://app.kmhis.com/multi/
了解软佳门诊管理系统详情https://www.kmhis.com/outpatient-management-system.html


扫码预约

手机扫码试用患者预约。请勿输入个人真实信息(点击图片可查看原图)

支持8种语言:简体中文、繁体中文、香港中文、English、藏文、泰文、老挝语、越南语


说真的。这类问题我见过太多了。每次看到医院同事为选型头疼。我就想,要是早点有人把这些经验分享出来就好了。毕竟。选择不对。后面全是麻烦。选择对了。省心省力。还能提升整个机构的运行效率。希望这篇能帮到正在纠结的你。

你如果有具体需求。也可以去 www.kmhis.com 看看。那里有更详细的技术方案和案例。

一次周到的回访:让赵主任主动把续约会提前半年

软佳实施完成三个月后,按照合同约定,第一年的免费运维期还剩九个月。按常规,下一年度的续约会谈通常提前三个月开始。

但一个工作日的上午,小张的手机响了,是XX医院信息科赵主任打来的。

“小张,你们能不能这周来一趟?有些事想当面聊。”

小张心里一紧。合同期还没到,赵主任这么急找上门,难道系统出什么大问题了?他赶紧查看最近的服务记录,没有收到任何紧急工单啊。

“赵主任,出什么事了吗?我立刻带工程师过去。”

电话那头笑了:”别紧张,系统好得很。我是想讨论明年的续约,能不能现在定下来?我还想加两个模块。”

小张愣住了。这他还是第一次遇到——客户主动要求提前续约,还要加功能。他看到过太多供应商追着客户签合同的场面,没想到自己会遇到相反的情况。

“您是说…现在就把下一年度的合同签了?”小张确认道。

“对。这周你们有空吗?”

1. 从”常规流程”到”主动邀约”

小张挂掉电话,立即给售后团队的老周打电话。老周是负责XX医院的技术支持工程师,过去九个月里,他每个月都去巡检一次。

“老周,你说赵主任为什么主动要续约?”

老周想了想:”可能跟我们的服务有关吧。这九个月,我们做了不少事,虽然按合同该做的都做了,但有些超出合同的部分…”

“比如?”

“比如我们主动做健康巡检,每次去都带一份详细报告,提前发现隐患。还有两次夜间紧急响应,我们都在两小时内到位的。另外上次系统升级,我们主动给医院写了一个数据迁移脚本,不收一分钱。”

小张明白了。这些事在软佳内部算不了什么——他们认为售后就应该主动、快速、贴心——但在客户看来,这是一种”超预期”的体验。他忽然想起一句话:最好的续约,不是追着客户签单,而是客户主动提出续约。

“走,我们现在就去医院,”小张对老周说,”带上所有服务记录。”

2. 过去九个月,我们做了什么?

XX医院信息科会议室。赵主任 already 等在那里,身边还有财务科的王科长。

“小张,老周,坐。”赵主任开门见山,”我想先跟你们说说,为什么我愿意提前续约。”

他拿出一份A4纸,上面列着三个要点:

1. 每月主动健康巡检

– 过去九个月,软佳的售后团队每月一次上门巡检,每次都提前发送检查报告,列出发现的风险和建议。

– 有两次巡检发现数据库连接数接近阈值,我们提前扩容,避免了高峰期的性能问题。

– 巡检报告非常详细, ours 工程师还会用通俗语言跟我们解释,让我们也懂技术风险。

2. 紧急响应快如闪电

– 合同承诺4小时响应,但软佳两次夜间问题都在2小时内解决。

– 有一次是凌晨一点,收费系统突然出现”重复记账”bug,我们财务科急死了。打电话给你们,老周半小时就到了,两个小时修复完成,第二天早高峰没受影响。

– 响应速度快,不仅解决了问题,更让我们感到”有靠山”。

3. 升级时的小礼物

– 三个月前,你们推送V2.5版本时,主动提供了一个数据迁移脚本,帮我们把旧数据迁到新结构,没额外收费。

– 很多供应商在升级时借机收钱,你们反而送”服务”。这说明你们不是为了短期利益,而是希望系统长期稳定。

赵主任抬起头:”这些事,看起来不大,但积攒起来,就是信任。”

小张感动了。他们没有刻意去”做续约准备”,只是按公司的服务理念——把每次服务做到位,把每个细节超出预期——结果客户就主动表达了续约意愿。

3. 信任建立:从”供应商”到”伙伴”

小张代表公司说话:”赵主任,您说的这些,都是我们应该做的。我们的理念是,售后服务不是’售后’,而是’伴后’——陪伴在客户身边,长期服务。”

赵主任笑了:”这个说法好。很多供应商把合同签完就换人,有问题找半天。你们不一样,从实施到运维,一直是同一批人,我们什么问题找谁,都熟悉。”

“其实,”老周插话,”我们更愿意把客户关系看成长期的。系统一旦上线,未来十年甚至更长时间都要维护,前期建立的良好沟通机制,会让后期合作顺畅很多。”

财务科王科长补充:”我们算过账,如果系统不稳定,每天因为效率损失、重复工作、患者投诉,隐性成本很高。而软佳的服务,让我们系统稳定性达到99.8%,这比省下那点服务费重要得多。”

赵主任点点头:”还有一点,你们不藏着掖着——每次有问题,都告诉我们真相,不推卸。这种透明,让我们很放心。”

4. 续约谈判:价格、服务与未来

谈话进入正题。小张拿出续约草案:

– 续约三年,价格按现行标准锁定,不涨价。

– 包含现有模块的维护、升级、技术支持。

– 额外增加两个模块:移动端离线编辑、AI辅助诊断提示。

– 保留每月巡检、4小时响应承诺(实际我们一贯更快)。

赵主任对价格很满意:”现在签,还能按现在的价格,三年不涨。过三个月再签,可能就要涨5%了。”

“我们珍惜像您这样的客户,”小张说,”提前续约,我们也能提前规划资源,双赢。”

最终,双方签署了三年续约协议,并当场确定了新模块的需求排期,三个月内上线。

赵主任在朋友圈发了条消息:> “软佳的服务,让’售后’这两个字该改改了,应该叫’伴后’。image: [握手表情]

这条朋友圈,医院圈子很多人都看到了。不久后,软佳的业务员说,有另外两家医院的领导主动来询问合作意向,提到”看到赵主任在朋友圈的推荐”。

5. 服务哲学的反思

事后,软佳内部开了个复盘会。周总说:”很多人以为续约靠销售技巧、靠关系、靠压价。但我们这次案例表明,续约不是销售的终点,是服务的自然结果。如果服务不到位,签了合同也留不住客户;如果服务到位,客户会主动续约,甚至帮你宣传。”

他总结了三点:

1. 主动服务创造惊喜

巡检、报告、提前发现问题——这些超出合同范围的动作,让客户感受到”这家公司在乎我的系统”。

2. 快速响应建立信任

4小时承诺,2小时做到,这个差距就是口碑。客户会记住关键时刻的及时救援。

3. 免费的价值最高

升级时送迁移脚本,看似损失一笔小收入,却换来客户的长期信任和转介绍。有时候,不赚钱的服务,反而带来更大的回报。

6. 客户关系维护的”铁三角”

基于这个案例,软佳把客户关系维护总结为”铁三角”:

定期主动体检:每月一次健康巡检,提前邮件发送报告,不等问题发生。

关键时刻在场:夜间、节假日问题不推脱,确保响应时间过半。

增值惊喜常态化:在能力范围内,为客户提供合同外的帮助——一个脚本、一次培训、一个优化建议。这些”小礼物”会让客户感到被重视。

“铁三角”的核心理念是:把客户当成长期伙伴,而不是一单生意。当你真心为客户好时,客户也能感觉到。

7. 从一次续约到更多转介绍

赵主任的朋友圈效应很快显现。

不到半个月,软佳陆续收到三家医院的咨询,提到”听赵主任说你们服务好”。其中一家直接表示,”如果能达到跟XX医院一样的服务标准,我们可以直接签三年合同”。

小张感悟:客户的成功案例,是最好的销售素材。与其自己夸自己,不如让满意的客户为你说话。而让客户满意的唯一方式,就是在服务过程中不断创造”超预期”的体验。

现在,软佳要求所有客户成功经理,在每次服务结束后,问自己一个问题:”客户会因为这次服务而更愿意续约吗?”如果答案是否定的,那就说明服务还有提升空间。

互动话题

你们的客户会主动续约吗?如果会,他们最看重的是什么?如果不会,你觉得卡在哪个环节?欢迎分享你们的客户关系维护经验。

> 基于真实医院场景改编,人物均为化名


立即免费试用门诊系统https://app.kmhis.com/
International Versionhttps://app.kmhis.com/multi/
了解软佳门诊管理系统详情https://www.kmhis.com/outpatient-management-system.html


扫码预约

手机扫码试用患者预约。请勿输入个人真实信息(点击图片可查看原图)

支持8种语言:简体中文、繁体中文、香港中文、English、藏文、泰文、老挝语、越南语


说真的。这类问题我见过太多了。每次看到医院同事为选型头疼。我就想,要是早点有人把这些经验分享出来就好了。毕竟。选择不对。后面全是麻烦。选择对了。省心省力。还能提升整个机构的运行效率。希望这篇能帮到正在纠结的你。

你如果有具体需求。也可以去 www.kmhis.com 看看。那里有更详细的技术方案和案例。