“违约金每天3%?”——那次差点把老板气疯的合同谈判,及条款背后的博弈智慧

会议室里,杨院长和采购办的刘主任,坐在一边。

周总和小张,坐在另一边。

桌上放着两份合同草案,一模一样,除了一个地方——延误违约金

软佳的版本:

> “如果系统上线延期,每延期一天,支付合同金额的0.5%作为违约金,上限为合同总额的10%。”

医院的版本:

> “如果系统上线延期,每延期一天,支付合同金额的3%作为违约金,上限为合同总额的50%。”

三倍差距。

周总看到医院的版本时,差点把水喷出来——580万的3%,一天17.4万,十天就174万,远超合同利润。

“刘主任,3%是不是太高了?我们580万的合同,延期一天就要赔17万?十天就赔170万,我们不用干了。”周总说。

刘主任淡淡地说:”周总,我们这么大的医院,每天门诊收入多少你知道吗?几百万。如果你们系统延期,我们门诊受影响,损失谁赔?3%已经是很客气了。”

周总没说话,心里在计算。

这合同没法签。延期一天赔17万,十天就破产了。

但不要这单,公司损失更大——这是年度最大的单,而且标杆意义重大。

1. 不能只谈”违约金”,要谈”责任归属”——引入对等条款

周总问了一个问题:”刘主任,如果延期,责任一定是我们吗?”

“合同白纸黑字,按时上线是你们的义务。”刘主任说。

“但如果延期是因为贵院的原因呢?比如,”

周总伸出指头:

– “你们提供的测试环境不稳定,导致我们无法测试”

– “或者你们需求变更频繁,导致我们返工”

– “或者贵院网络不通,我们集成不了”

– “或者贵院人员不配合,签字审批延迟”

– “或者第三方厂商(如硬件供应商)延迟交货”

刘主任被问住了。

“合同条款,不能只说’你要赔’,还要说’如果是我造成的,我不但要你赔’。”周总打开带来的笔记本,”我们带来了一个’对等责任条款’草案,您看看。”

草案内容:

– 双方任何一方违约导致延期,都应向对方支付违约金

– 违约金的计算方式,基于造成的实际损失(而不是固定比例)

– 如果延期由双方共同原因造成,按责任比例分摊

– 有一方故意或重大过失,承担主要责任

刘主任摇头:”我们要的是保障。按你们的草案,真出事了,你们一句’医院也有责任’,就不用赔了?”

“不是不用赔,是照实赔。”周总说,”但关键是,我们要先定义什么叫’延期’。”

2. “上线”的定义:验收标准必须清晰

周总拿起笔,在白板上画了一个时间轴:

“`
需求确认 → 设计 → 开发 → 测试 → UAT → 上线
“`

“刘主任,请问’上线’是指哪一天?”

“系统正式投入使用那天。”

“那UAT(用户验收测试)通过,算上线吗?如果不算,UAT到正式上线之间,如果出问题算谁的责任?”

刘主任说:”UAT通过,就算验收合格,应该付尾款。之后的事,是运维。”

周总摇头:”UAT是通过了,但正式上线第一天,医生不会用,护士站报错,财务对账有问题——这些算系统的质量问题吗?还是算培训不到位?上线第一个月内的故障,算不算延期?”

刘主任语塞。

周总提出一个方案:阶梯式验收

1. 技术验收:UAT通过,功能符合需求 → 付90%合同款

2. 业务验收:正式上线后7天内,核心业务零重大故障 → 付5%

3. 稳定运行验收:上线后30天,系统可用率>99.9% → 付最后5%

如果前两步失败,责任在我们,我们整改,不额外收钱;如果最后一步失败,我们有义务继续整改,但不触发违约金。

“这样,’上线’的定义就清晰了,责任划分也清楚。”周总说。

刘主任想了想:”如果业务验收失败,我们不是还得等?”

“是,但这是双赢——你们要的是稳定系统,不是按时交付但一堆bug的系统。”周总说。

杨院长插话:”这个阶梯验收,合理。”

3. “重大故障”的量化定义:避免事后扯皮

刘主任终于松口了阶梯验收,但加了一个条件:

“如果上线后一个月内,出现三次以上’业务中断’(比如门诊挂号失灵、住院无法入出转),除整改外,每发生一次,扣减尾款1%。”

周总心里算了一下:尾款5%,三次就扣3%,相当于少赚六十多万。

“这个可以,但需要定义什么叫’业务中断’。”

“挂号系统不能用,收费系统不能用,就是业务中断。”

“那如果只是某个功能慢一点,但没有完全不能用,算吗?”

“不算。”

“如果某个科室因为网络问题,不能用,但其他科室能用,算吗?”

“要看影响范围。影响全院,算;影响单个科室,不算。”

周总继续追问:”影响50%以上的科室,算吗?”

“算。”

周总把它写进条款:

> “业务中断”定义为:影响超过50%用户的系统功能不可用,持续时间超过15分钟

“这样明确,双方都有数。”

刘主任点头。

4. 需求变更:最毒的”隐性延期”陷阱

刘主任最后提了一个要求:”合同里要写清楚,如果需求变更,你们必须配合,不得推诿。”

周总笑了:”刘主任,任何变更,都是有成本的。我们可以配合,但需要有个流程:**

– 变更申请(书面)

– 评估影响(工期、成本)

– 双方签字确认

– 执行**

“那是不是我们每次提变更,你们都要加钱?”

“不一定。如果变更很小,不影响工期和成本,可以免费。但如果变更大,增加了工作量,我们需要相应调整合同金额和工期。”

刘主任不同意:”合同价格不能变。”

周总:”那我们就严格按需求来。如果需求之外的变更,我们不做,或者另签补充协议。”

这是底线。

刘主任想了想:”可以,但变更评估要公正,不能你们说多少就多少。”

周总:”评估我们可以一起做,用你的需求文档和我们的工时表。第三方介入也可以。”

刘主任:”那评估周期多长?”

“三个工作日。”

“太长!”

“太短评估不准。三天是底线。”

5. 最终敲定的核心条款

经过两轮谈判,合同条款基本定稿:

1. 交付与验收

– 分三阶段验收:技术验收(UAT通过)→业务验收(7日无重大故障)→稳定验收(30日可用率>99.9%)

– 每阶段验收通过,支付相应比例款项(90%→5%→5%)

2. 违约金

– 仅针对”技术验收延期”(从合同约定日期到UAT通过)

– 违约金=延期天数×合同金额×0.3%(原0.5%)

– 上限=合同总额的10%(原50%)

– 如果延期是医院方原因导致(如需求变更、评估延迟、环境问题),医院方需补偿我方额外成本(按实际工时计算)

3. 业务中断

– 定义:影响超过50%用户,持续15分钟以上

– 验收期内每发生一次,扣减尾款1%(最多扣3%)

– 验收期后,进入运维期,业务中断不计入违约,但列入服务考核

4. 需求变更

– 医院方提交变更申请

– 双方共同评估影响(工作量、工期)

– 如果影响工期内完成,免费;否则,签补充协议调整价格和工期

5. 知识产权

– 软件开发成果归医院所有

– 但软佳保留软件著作权(这是行规)

– 医院获得永久使用许可,可自行维护或委托第三方维护

6. 付款方式

– 合同签后预付30%

– UAT通过后付60%

– 稳定验收后付尾款10%(原5%)

6. 这个条款,后来救了两方的命

合同签订后,项目进行到一半,医院提出一个”小变更”:在医嘱界面加一个”过敏史提醒”弹窗,医生开药时自动显示患者过敏史。

评估发现:这个”小变更”涉及三个模块的接口调整(患者主数据、医嘱、药方),需要重新做兼容性测试,增加工作量15人天。

按合同,应该签补充协议。

医院说:”我们就加个弹窗,为什么要加钱?”

周总说:”不是弹窗简单,是它要对接患者过敏史数据库,要实时查询,要弹窗样式审批,要护士站测试,要更新用户手册…这些工作量不小。”

刘主任起初不同意,后来想起合同条款,只好认:”那签补充协议吧。”

补充协议签了,增加合同额12万,工期延长10天。

如果没有这个条款,医院可能强行要求”免费加功能”,导致项目延期,然后医院又要按延期违约金扣款——软佳就冤死了。

反过来,如果软佳想随意涨价,医院也可以拿条款约束。

7. 合同不是”敌我条款”,而是”游戏规则”

周总后来在软佳内部培训时,说:

“很多销售,把合同当成’签下来就完事’,条款都是模版,客户爱签不签。

但一份好的合同,不是’敌我条款’——不是只保护一方,是(‘平衡条款’)。”

它应该:

– 明确责任边界,避免后期扯皮

– 提供变更渠道,让变化有章可循

– 尊重双方的合理诉求

“客户签合同时不舒服,后期执行就会更不舒服。相反,如果客户觉得条款公平,后期配合度也会高。”

“我见过最糟糕的合同,是那种’我全赢,你全输’的条款。客户签的时候迫于压力签了,后期处处找茬,恶意延期验收,恶意扣款,最后打官司。”

“好的合同,是(‘双赢框架’)——虽然是一场博弈,但博弈的结果是双方都能接受。”

“这次XX医院的合同,就是典型案例。违约金我们谈下来了,但我们也接受了’阶梯验收’和’业务中断扣款’,这些对客户是保护,对我们也是鞭策——逼着我们把系统做稳定。”

8. “合同精神”比”合同文本”更重要

合同签了,但执行中还是有问题。

有一次,医院方在验收时,故意鸡蛋里挑骨头,说”某个按钮颜色不对”,要扣5%尾款。

周总找刘主任:”这个不算重大故障,是UI细节,不触发扣款条款。”

刘主任说:”我们不扣款,但你们得改。”

周总:”可以改,但要走变更流程,加钱。”

刘主任:”这么小的事也要加钱?”

“这不是大小的事,是原则的事。”周总说,”如果今天颜色不对扣款,明天字体不对也扣款,后天是不是功能不对也要扣款?合同里的’业务中断’有明确定义,颜色不对不算。”

刘主任被噎住了。

最后,软佳免费改了那个按钮颜色——因为确实是小事,没必要闹僵。

但周总强调:原则问题不能让

“合同是底线。如果客户随意突破底线,以后会更难合作。”

9. 合同的”兜底条款”:不可抗力

周总还特别加了一条”不可抗力”条款:

> “因地震、洪水、战争、大规模网络攻击等不可抗力导致的延期或故障,双方互不承担违约责任。”

刘主任问:”大规模网络攻击也算?”

“算。”周总说,”现在的系统,DDoS攻击、勒索软件,都是真实风险。我们不能让客户承担’黑客’的后果。”

刘主任以为然。

这条款后来真的用上了——半年后,有黑客攻击了医院内网,虽然不是HIS系统,但医院网络瘫痪了4小时。软佳没有因此被扣款。

10. 合同谈判的”终极心法”:让客户感觉”赢了”

周总的谈判哲学:

① 永远不要只防守

– 不要只说”这个不能改”

– 要说”这个不能改,但我可以在其他地方补偿你”

② 给客户”赢”的感觉

– 价格不降,但送服务

– 条款不让,但提供额外保障

– 客户要的是”好处”,不是”让步”

③ 把”我的利益”包装成”我们的利益”

– “违约金太高对我们都不好——我们亏钱了,你们也得不到好服务”

– “分级验收对你们也好——你们要的是稳定系统,不是按时交付但一堆bug的系统”

④ 用数据说话,不用情绪

– 周总从不跟刘主任吵架

– 每次讨论,都拿出白板,写写画画,算账

– 账算清楚了,情绪就少了

互动话题

你签过最公平/最不公平的合同条款是什么?

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


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


扫码预约

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

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


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

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

那个”万能密码”用了三年:一次权限管理的觉醒

“系统出错了!”

信息科李主任刚上班,就接到药房电话。

药房馮主任在电话里嚷:”为什么我登录系统,提示’密码过期’?我昨天还能用!”

李主任心里一沉。

药房系统,用的是全院统一的”管理员账户”——用户名admin_yaofang,密码是Yaofang@2023

这个密码一年前就该过期了,但冯主任一直没改。不是他不想改,是改了之后,药房十几台电脑都要手动更新密码,很麻烦。

而且,这套密码,从2023年用到现在,从来没出过问题。

但今天,突然提示密码过期。

李主任查了一下密码策略:密码有效期是180天。Yaofang@2023是2023年10月设置的,到今天已经超过500天了。

奇怪,为什么系统突然开始强制改密码?

他打开密码策略配置——有效期还是180天,但”密码历史记录”被改成了”记住5次”。而且,”密码必须复杂性”被开启。

“有人动过密码策略。”李主任说。

他查变更日志,发现是上周安全加固时,小吴改的。

小吴来了,解释:”我发现全院所有科室的管理员密码,都是’科室名@年份’,太简单了。我就把策略调严了:必须大小写字母+数字+符号,8位以上,180天过期,不能重复使用。”

“但药房不知道啊,”李主任说,”他们没收到通知。”

“系统登录的时候会提示。”

“但提示了为什么不改?冯主任说,他点了’确定’,登录还是失败。”

小吴查了一下:”哦,新密码策略要求密码不能包含用户名。冯主任如果设成’Yaofang@2024’,就包含了’Yaofang’,不符合策略,所以设失败。”

李主任明白了:这是一个典型的”好心办坏事”——安全策略变严了,但用户不知道怎么设置合格的新密码,导致集体被锁。

1. “万能密码”的发现

但这件事,只是冰山一角。

当天下午,老周来信息科做客,李主任跟他抱怨:”我们这权限管理,一团糟。”

老周问有多乱。

李主任打开用户管理后台,给老周看:

发现一:存在”万能账户”

– 有个用户叫admin_backup,密码是Admin@123456

– 这个账户的权限是”超级管理员”,但没人知道是谁创建的

– 最后一次登录是半年前,但账户状态是”启用”

李主任说:”这个账户是V2.0时代留下的,那时开发商留的后门。V3.0迁移时忘了删。”

发现二:科室共用账户严重

– 药房:admin_yaofang(5人知道密码)

– 住院处:admin_zhuyuan(3人知道密码)

– 财务科:admin_caiwu(4人知道密码)

– 检验科:admin_jianyan(2人知道密码)

密码都是”科室名@年份”,而且五年没改过。

“为什么这么乱?”

“因为一旦改密码,所有科室电脑都要同步更新,很麻烦。而且我们系统没有单点登录,每个科室都要独立账户。”李主任说。

发现三:权限虚高

– 门诊挂号岗的账户,有”删除挂号记录”权限

– 护士站的账户,有”修改药品价格”权限

– 医嘱开立岗的账户,有”删除医嘱”权限

“这些高权限,是出厂设置,我们没细调。”

老周看着后台,摇头:”这就像一个家,钥匙分给所有邻居,而且钥匙上贴着’万能’两个字。”

2. 老周的建议:三管齐下

老周给李主任提了三个建议:

1. 清理账户,最小权限原则

– 删除所有未使用的账户(尤其是admin_backup

– 所有账户按角色分配权限:挂号员只能挂号,收费员只能收费,护士只能执行医嘱

– 每个角色,只给”必须”的权限,不给的权限,一个都不要给

2. 推广单点登录(SSO)

– 医院职工用一个账号(工号)登录所有系统

– 密码只需改一次,所有系统同步更新

– 极大减少”共用账户”现象

3. 建立账户生命周期管理

– 新员工入职,自动创建账户

– 员工调岗,自动调整权限

– 员工离职,24小时内禁用账户

– 定期(每季度)审计所有账户,清理僵尸账户

3. 实施中的”人性化”难题

但实施起来,困难重重。

第一关:清理”admin_yaofang”这类共用账户

李主任在信息科会上提出:药房今后不再使用admin_yaofang,改为每人一个独立账户。

冯主任当场反对:”我们药房十几个人,每人一个账号,那密码怎么管理?出问题谁负责?”

“你们现在共用一个密码,出了问题谁负责?”李主任反问。

“现在也没出问题啊。”

“刚才的密码过期事件,不就是问题吗?”

冯主任不说话了。

李主任提出妥协方案:

– 先为药房所有在职人员创建独立账户

– 保留admin_yaofang账户,但降权为”只读”

– 过渡期一个月,期间两种账号都可以登录,但鼓励用个人账号

– 一个月后,禁用admin_yaofang

冯主任勉强同意。

但执行时,很多人不配合——”用哪个账号不是用?为什么非要改?”

李主任只有硬着头皮,一家家科室去沟通,解释安全风险。

第二关:角色权限细化

老周带着实施团队,开始梳理所有岗位的权限。

工作量巨大:医院有五十多个岗位,每个岗位有上百个操作权限。他们要做的,是为每个岗位,设计”最小必要权限集”。

比如”挂号员”:

– ✅ 能创建门诊挂号记录

– ✅ 能查询患者历史就诊

– ✅ 能退号

– ❌ 不能修改挂号费(财务的事)

– ❌ 不能删除挂号记录(数据安全)

– ❌ 不能开医嘱(业务隔离)

但细化后,业务部门又有意见:

“我们有时候需要帮病人改个联系方式,为什么不能’修改患者信息’?”

“我们偶尔要退号,为什么’删除挂号记录’不行?”

老周的解释是:权限分配,不是按”当前需求”,而是按”职责边界”

如果挂号员需要频繁改患者信息,那应该增加一个”患者信息维护岗”,而不是给挂号员这个权限。否则,每个人都是全能,出了事谁的责任?

但医院觉得这样太”死板”,影响效率。

老周让步:增设一个”高级挂号员”角色,权限比普通挂号员多几条(如修改患者联系方式),申请这个角色需要科室主任批准。

4. SSO上线后,各部门”不习惯了”

三个月后,单点登录系统上线。

所有科室,终于只有一个账号、一个密码。

理论上,密码安全度提高了——统一密码策略要求:12位,大小写+数字+符号,90天过期,不能和历史密码重复。

但实施后,负面反馈来了:

“密码太复杂了,记不住!”

“三个月就过期,太频繁了!”

“我手机不能记密码,每次都要问同事!”

冯主任更是直接找到李主任:”药房现在有两个人同时操作一台电脑,一个人输入密码登录,另一个人就用同一个账号继续操作。这跟以前共用账户有什么区别?”

李主任哑口无言。

这是”安全”与”便利”的永恒矛盾。

5. 老周的平衡之道

老周听完李主任的抱怨,说:”我们是不是把目标定错了?”

“什么目标?”

“我们以为目标是’安全’,其实目标应该是‘可控的安全’。”

“什么意思?”

“绝对的安全,会带来绝对的不便。比如每个操作都要二次验证,那业务就不用做了。安全措施,必须考虑用户的接受度。”

老周调整了策略:

1. 密码策略适度放松

– 长度从12位改为10位

– 复杂度要求保留,但增加”密码短语”支持(允许用句子,如”IloveHIS2024!”)

– 过期时间从90天延长到180天

2. 增加”二次认证”选择性

– 对于普通操作,只用密码

– 对于高危操作(删除、修改价格、批量导出),强制手机验证码

– 这样,日常使用不受影响,高危操作有保护

3. 推广”扫码登录”

– 每个科室电脑,贴一个二维码

– 职工用自己的手机扫码,免密登录

– 手机有生物识别(指纹/面容),安全和便利兼顾

4. 定期安全培训

– 教职工识别钓鱼邮件

– 教育密码管理常识(不要写在便签上)

– 通报安全事件案例

6. 一年后的变化

一年后,李主任再次盘点权限管理:

– 共用账户:从原来的12个,减少到2个(特殊场景,已申请保留)

– 个人账户:全院95%职工有独立账户

– 僵尸账户:清理了37个(离职未禁用)

– 权限事故:0次

– 密码相关求助电话:从每月20+次,降到2-3次

冯主任现在也适应了:”用扫码登录,确实方便。而且密码一年才改一次,能接受。”

老周来检查时,李主任说:”我现在觉得,权限管理不是’技术活’,是’管理学活’。你不仅要懂技术,还要懂人心。”

“怎么讲?”

“技术方案再完美,如果用户不接受,就是废纸。你不能指望医院人员都有IT专业素养。你必须把安全措施,做得像呼吸一样自然——用户甚至感觉不到’我在遵守安全规则’,这才是成功的。”

7. “最小权限”不是”最小信任”

李主任后来在一次省内HIS安全交流会上,分享了他的心得:

“很多领导觉得,权限管理是’防着自己人’。其实不是。

‘明确责任边界’

当每个人只有自己的权限,干了什么操作都能追溯到人,出了问题,就知道是谁的责任。

反过来,如果大家用的是同一个账户,出了事,互相甩锅,查不清。

所以,最小权限原则,表面上是限制,实际上是保护——保护了守规矩的人,也约束了不守规矩的人。

而且,给了每个人独立的账户,是对他们的尊重——’你是独立的个体,有你的职责和权限’。

共用账户,意味着’你只是系统的一个使用者,没有身份’。

这是两回事。”

互动话题

你们单位的账号密码管理是什么情况?有没有”万能密码”?

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


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


扫码预约

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

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


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

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

凌晨三点,一个电话打给了周总——服务响应的”生死时速”

“周总,出事了。”

凌晨三点,周总被电话叫醒。

电话是XX医院护理部陈护士长发来的,声音很急,带着哭腔:”我们护士站,突然批量出现’医嘱无法执行’,几十个护士等着用药,病人家属都围过来了。有病人等着急救,系统不响应,我们在用手写…”

周总立刻清醒了。

这是XX医院HIS系统上线后第四个月,第一次出现大规模的在线故障。

他一边穿衣服,一边打电话给小张(项目经理)、小刘(运维负责人)、小李(DBA)。

“一级响应,所有人半小时到医院。带上笔记本电脑、备份U盘、应急工具。”

半小时后,三人都到了医院信息科。

李主任已经在了,脸色很难看,在走廊里来回踱步。

“什么情况?”周总问。

“大约半小时前,开始有护士报错:’医嘱执行失败,系统错误’。起初是个别现象,我们以为是网络问题。但不到十分钟,半个医院的护士站都报错。现在门诊、住院的药房系统也受影响,没法发药。”

周总和团队冲进机房。

1. 紧急排查:从”症状”到”根因”

小刘开始查日志。

日志显示:”医嘱执行”这个接口的错误率,从0%飙升到了87%。错误信息是”数据库连接超时”。

但数据库连接池正常(使用率60%),CPU使用率正常(45%),网络也正常(延迟1ms)。

“不是连接不上数据库,”小刘说,”是某个查询特别慢,把连接占住了。”

“哪个查询?”

“”获取待执行医嘱列表”这个接口。平时这个接口300毫秒,现在有的请求要15秒。”

小刘调出那条SQL:

“`sql
SELECT o.order_id, p.patient_name, d.drug_name, o.status
FROM orders o
JOIN patients p ON o.patient_id = p.patient_id
JOIN drugs d ON o.drug_id = d.drug_id
WHERE o.status = ‘待执行’
AND o.created_time >= DATE_SUB(NOW(), INTERVAL 1 DAY)
ORDER BY o.priority DESC, o.created_time ASC;
“`

“为什么突然变慢?”周总问。

小吴查了一下:”这个SQL,最近一次代码变更是一周前,加了ORDER BY o.priority。但上周压测通过了啊。”

“数据量现在多大?”

“orders表,加上四月份的数据,现在有230万行。’待执行’状态的,大概15万行。”

老周看执行计划:

o.status 有索引(status_idx)

o.createdtime 有索引(createdtime_idx)

– 但ORDER BY o.priority没有索引

– MySQL选择用status_idx,扫描15万行,然后排序15万行

这就是问题所在——“文件排序”(filesort)导致性能雪崩

小吴说:”上周压测时,数据量只有50万,’待执行’只有3万,排序很快。现在量大了三倍,排序变慢10倍。”

周总:”加个组合索引:(status, priority, created_time),能不能解决?”

小吴:”可以,但需要锁表。online DDL也要10分钟,现在能用吗?”

现在门诊还在运行,锁表会雪上加霜。

2. 紧急处理:降级、扩容、加索引,三管齐下

老周决定三管齐下:

第一步:功能降级

– 临时关闭”优先级排序”,按created_time排序就够了

– 改SQL,去掉ORDER BY priority

– 热更新配置,不需要重启

– 5分钟完成

效果:查询时间从15秒降到2秒,但还不够(正常应该<500毫秒)

第二步:扩大连接池(临时)

– 连接池从50扩大到100

– 防止其他功能因为等待连接而卡住

– 效果:其他接口恢复正常

第三步:热加索引

– 给orders表加组合索引:idxstatusprioritytime (status, priority, createdtime)

– 使用MySQL的ALGORITHM=INPLACE, LOCK=NONE在线加索引

– 预计时间:15分钟

– 期间性能会有轻微下降

小吴开始执行。

但加索引到一半,出事了。

3. 危机升级:磁盘空间不足

数据库日志报错:”磁盘空间不足,无法创建索引”。

小李查磁盘空间:

– C盘(系统盘):剩余5%

– D盘(数据盘):剩余3%

– 日志文件占用空间,从三个月前的50GB,增长到了160GB

“日志为什么占这么大?”老周问。

信息科老陈说:”系统日志级别设为了DEBUG,每条SQL都记录。平时没事,但上线后bug多,日志量大增。我们还没来得及调整。”

而且,自动日志清理任务,上周执行失败了——因为没人检查执行结果。

老周明白了:这不是单一原因,是系统性的运维意识薄弱

几个环节:

– 日志级别不合理(DEBUG级别太细,应该WARN或ERROR)

– 没有监控磁盘增长(告警阈值设为5%,等发现时已经太晚)

– 自动清理任务失败了没人管(有执行,没验证)

三个小问题,叠加在一起,造成了大故障。

老周当机立断:

1. 临时删除最占空间的三个非核心索引(历史遗留,很少用)

2. 清理一周前的日志文件(压缩备份后删除)

3. 调整日志级别为WARN

4. 加索引继续

折腾了40分钟,腾出30GB空间。

索引终于加完。

效果立竿见影:

– 那个查询从2秒降到80毫秒

– 系统错误率从87%降到0%

早上四点三十分,系统恢复。

护士们终于能正常开医嘱、发药了。

4. 根因分析:一个”小疏忽”引发的大事故

事后,周总主持了深度复盘。

参与的包括软佳团队、信息科、护理部代表。

周总先问了一个问题:”这次故障,直接原因是SQL慢。但SQL为什么慢?”

小吴:”因为数据量大了,排序开销大。”

“数据量大是突然发生的吗?”

“不是,是按月增长的,四月份增加了30%。”

“那为什么我们没有提前预警?”

没人说话。

周总自己回答:

1. 没有容量规划——不知道数据增长趋势,不知道索引会失效

2. 没有性能回归测试——上周改代码时没测这个查询在新数据量下的表现

3. 没有监控磁盘空间——告警阈值5%太低,应该20%就预警

4. 没有自动任务验证——日志清理任务失败没人发现

5. 没有紧急响应预案——遇到磁盘满不知道优先做什么

“这不是技术问题,是运维管理问题。”

5. “救火”后,我们做了三件事:从”被动响应”到”主动预防”

周总回到公司,没睡觉,而是组织了一次”售后复盘会”。

他做了三件事:

① 建立”预防性运维”清单

软佳为客户提供的”月度健康检查”清单,增加了五项:

– 检查磁盘空间增长趋势(提前发现数据膨胀)

– 检查自动任务执行日志(确保任务没silently失败)

– 检查日志文件大小和级别(适时调整,避免占满磁盘)

– 检查慢查询日志(及时优化,防止雪崩)

– 检查缓存命中率(防止缓存失效导致穿透)

② 推出”健康巡检”服务

每月一次上门,免费为医院做系统健康检查。

检查清单包括上面那五条,再加上:

– 备份有效性验证(备份能否恢复)

– 安全补丁状态(操作系统、数据库、中间件)

– 性能基准测试(对比上月,看是否退化)

巡检后给一份报告,列出风险和建议。

“这个服务,目前免费。”周总对李主任说,”但半年后,如果你们觉得有价值,我们可以签年度服务协议,一年18万。”

李主任点头:”你们想得挺周到。”

③ 为所有客户做一次”紧急响应演练”

模拟各种故障场景:

– 磁盘满

– 数据库死锁

– 网络中断

– 应用OOM

– Redis宕机

演练工程师的响应流程:

1. 告警确认(5分钟内)

2. 快速定位(15分钟内)

3. 临时解决(30分钟内)

4. 根因分析(4小时内)

5. 整改(24小时内)

评估:响应时间、解决效率、沟通质量。

周总说:”这次凌晨故障,暴露了我们应急流程的问题。人员到场时间是30分钟,太长。下一次,我们要做到15分钟内响应核心故障。”

6. “售后服务”才是真正的营销:最好的销售是解决危机

三个月后,周总正在给另一家医院(ZZ医院)做巡检。

这家医院的情况,比XX医院还糟糕:

– 日志文件300GB,占满了C盘

– 数据库有137个未使用的索引,拖慢写入

– 有一个批量任务(每晚跑),每天凌晨跑5小时,但业务不知道它在跑什么

– 磁盘监控是摆设,告警一直没处理

周总边检查,边对信息科主任说:”你们这系统,就像一个从不保养的汽车,勉强能开,但随时可能抛锚。”

主任苦笑:”我们这不是不知道要保养吗?”

周总帮他制定了年度运维计划:

– 每月健康巡检

– 每季度性能调优

– 每年架构评审

– 每半年灾难演练

“签个服务协议吧。”周总说,”我们帮你们把系统养好,你们能安心用。”

主任问:”多少钱?”

“一年18万。”

主任心里一算:请一个专职DBA,一年工资都不止这个数。还有监控工具、巡检成本…

“签。”

7. 售后服务的”心法”:从”成本中心”到”利润中心”

周总后来在一次行业会议上,分享了他的”售后服务经”:

“很多人觉得,售出产品,销售就结束了。但我觉得,售出产品,销售才刚开始。”

“产品就像种子,售后就是浇水、施肥、除虫。没有好的售后,再好的种子也长不好。”

“而售后,是最好的营销。”

为什么?

因为客户在遇到问题时,最能感受到你的价值。

产品一帆风顺时,客户觉得”这系统还行”;但出问题时,你响应快、解决得好,客户会觉得”这公司靠谱”。

(“一次成功的应急响应,胜过十次销售拜访”)

XX医院那次凌晨故障,我们到场半小时,解决问题两小时。事后,他们信息科主动给我们介绍了一家新客户。为什么?因为他们 seeing 了我们的责任心和专业能力。

所以,售后服务不是成本,是投资。

而且,这个投资的回报率,非常高——一个满意的老客户,会带来新客户;一个不满意的客户,会带走一片客户。

软佳后来成立了”客户成功部”,不再是简单的”售后技术支持”,而是”客户成功经理”制。

每个客户,配一名成功经理,职责:

– 定期巡检

– 主动优化

– 健康度评估

– 需求收集

– 续约推进

成功经理的KPI,不是”处理了多少工单”,而是:

– 客户健康度评分

– 系统可用率

– 故障次数趋势(下降)

– 客户NPS

– 续约率

这个部门,成了公司增长最快的部门——不是因为签了多少新单,而是老客户续约率从75%提升到了92%。

“很多公司,把售后当成本中心。”周总说,”我们把它当利润中心。”

解释:一次成功的售后,带来口碑,带来新客户,新客户的第一年收入,就是售后部门的”贡献”。老客户续约,也很大程度取决于售后体验。

所以售后部门创造的”间接价值”,远超其人力成本。

8. 凌晨电话,是信任的信号

陈护士长后来给周总发了条短信:

“周总,那天凌晨不好意思,打扰你们了。但说真的,你们来得很快,解决得很快。护士们都说,软佳的人,靠谱。”

周总把这条短信,贴到了客户成功部的墙上。

他说:”这条短信,比任何销售合同都有价值。因为它是客户在情绪最焦虑的时候,发给我们的——这种时候的信任,是最真的。”

9. 售后服务的”三个层次”

周总把客户关系,分为三个层次:

第一层:交易关系

– 你给我钱,我给产品

– 履约即结束

– 容易替代(谁便宜选谁)

第二层:服务关系

– 有问题,响应快

– 有需求,能满足

– 有感情,但不多

– 不太容易被替代

第三层:伙伴关系

– 主动发现客户问题(巡检发现问题,不等客户报)

– 帮客户规划未来(需求 roadmap)

– 为客户的失败感到难过,为客户的 success 感到高兴

– 很难被替代——因为客户觉得你”懂”他

软佳在向第三层努力。

而华通,还在第一层——赵某每次来,就是”我们有个新功能,您要不要看看?”

10. 售后响应”黄金一小时”原则

周总后来制定了一个”售后响应标准”:

一级告警(业务中断)

– 响应时间:5分钟内确认

– 支持人员到场:15分钟内(同城)

– 临时解决:30分钟内

– 根因分析:4小时内

– 根治方案:24小时内

二级告警(性能严重下降)

– 响应时间:15分钟内确认

– 临时解决:2小时内

– 根因分析:24小时内

三级告警(功能异常,但不影响核心业务)

– 响应时间:1小时内确认

– 解决时间:24小时内

“我们卖的不是软件,是’7×24小时安心’。”周总说。

客户买的是功能,但期待的是服务保障

互动话题

你有遇到过”超出预期”的售后服务吗?是什么让你觉得”值了”?

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


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


扫码预约

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

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


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

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

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

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

凌晨两点,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医院每月发生一次,甚至成了常态。信息科认为医务科提的需求天马行空、不切实际;医务科认为系统难用、信息科不接地气。两边互相指责,项目推进缓慢,凡是要跨部门协作的事情,总是陷入扯皮和僵局。

医务科赵主任和信息科李主任的关系尤其紧张。每次医院要上线新功能,赵主任都会提一大堆”我们临床需要”的要求,李主任则一条条驳回:”这个技术上实现不了”、”那个会破坏数据一致性”、”你们自己想清楚业务流程再来说”。赵主任气得摔杯子,李主任冷着脸说”你情绪化不能解决问题”。

前线医生和护士感受最深:医嘱模板复杂得像迷宫,找一个常用药要点击五六次;保存一条医嘱要经过四五个确认弹窗(”确定要开这个药吗?”、”病人过敏史检查了吗?”、”剂量确认”…),频繁操作时烦不胜烦;医生查房时用PDA写口头医嘱,护士要在治疗室专门一台电脑上确认执行,跑来跑去——信息科的人根本不在现场,他们怎么知道我们有多忙?

院长办公会上,杨院长听着各个科室的汇报,眉头越皱越紧。新功能推进表上,一堆项目延期;客服热线统计,医务科的投诉里有40%是针对系统易用性;信息科也抱怨,医务科的需求频繁变更,今天要这样明天要那样,让开发团队无所适从。

“为什么新功能总是推不动?”杨院长环视全场,”你们是不是要学会换位思考?信息科不能只坐在办公室写代码,要了解临床的真实痛点;医务科也不能一味提要求,要考虑技术实现成本和系统稳定性。双方要有同理心,要协作,不是对抗。”

散会后,赵主任和李主任都没走。两人站在走廊,气氛尴尬。

“赵主任,”李主任先开口,声音比较平和,”我知道你们临床忙,但有些需求确实技术上难实现,或者会影响系统整体架构。”

“我也知道你们有难处,”赵主任接过话,”但我们每天面对病人,时间就是生命。系统难用,直接耽误诊疗效率。”

沉默了几秒,赵主任忽然说:”要不…我们俩一起值班一天?互相体验对方的工作?”

李主任一愣,随即点头:”好。我跟你去病房,你也来信息科坐坐。”

1. 互换体验:坐在信息科工位的医务科主任

第二天,赵主任真的穿上了白大褂——不,他没有穿白大褂,而是换了一身便装,悄悄来到信息科,坐在一台空闲的电脑前。

“我想试试写一条医嘱模板,”赵主任对小张说,”就是给术后病人的常规镇痛方案。”

小张给他演示:登录系统,进入医嘱模板配置界面,选择”西药”,然后展开”镇痛类”子菜单,再选择”阿片类”,再点”常见配比”… 赵主任跟着操作,眼睛睁大了:”这么多选项?我们临床常用的其实就那三四种,其他很少用。为什么不全列出来?”

“这些是药品库的所有分类,我们按药理作用组织的。”小张解释。

“但我需要的是快速找到我常用的,不是看你们怎么分类的。”

继续操作:添加完药品,设置剂量、频次、疗程。每加一项,都有下拉选择或填写框。保存时,弹窗出现了:

“`
确认保存此模板吗? (1/5)
“`

赵主任点”确定”。

“`
请确认该病人无药物过敏史? (2/5)
“`

“这怎么知道?系统不会自动查吗?”赵主任皱眉。

“需要人工确认。”小张说。

接着是:

“`
保存后模板将对所有科室可见,是否继续? (3/5)
“`

“`
该模板可能涉及高风险药品,请再次核对剂量 (4/5)
“`

“`
您确定要保存吗?(最后一次确认) (5/5)
“`

“我要保存一条常用模板,要经过五次确认?!”赵主任快疯了,”我们医生一天要开几十条医嘱,每条都这样,非疯了不可!”

小张苦笑:”这些确认弹窗很多是早期版本加的,说是为了防止误操作。结果现在过度提醒了。”

赵主任花了15分钟,终于完成了一条最简单模板的创建。他感受深刻:”你们这个界面,是给’新手’设计的,不是给’高频使用者’。我们临床医生,天天用,需要的是效率,不是每一步都要确认。”

他坐在那里,试着又创建了一条抗生素模板,过程依旧繁琐。”难怪我们临床抱怨系统不好用——这设计确实反人类。”他喃喃道。

2. 互换体验:穿上白大褂的信息科主任

就在赵主任体验信息科的同时,李主任穿上白大褂(真穿了),跟着赵主任去病房查房。

上午9点,住院部已经开始忙碌。赵主任带着住院医师、护士,推着治疗车,一间间病房查看术后病人。

走到3床,一位刚做完阑尾炎手术的中年男性。赵主任站在床边,用PDA(handheld device)翻开电子病历,查看昨日医嘱执行情况。”今天感觉怎么样?伤口还疼吗?” 他口语输入:”今日疼痛评分3分,追加一次镇痛泵。”

护士小李站在治疗车旁,用另一台PDA确认:”收到医嘱,镇痛泵q8h prn,现在执行。”

李主任在一旁看着,心里有些触动。这套流程,在信息科的需求文档里是一行行文字:”移动医嘱录入”、”移动医嘱确认”。但实际场景是:医生在病人床边,弯腰或蹲下(因为病人躺在床上),光线可能不好,环境嘈杂;护士在治疗车边,有多个病人要照顾。

“你们用这个PDA,信号稳定吗?” 李主任问。

“有时候走廊信号差,指令发不出去,要到护士站才能同步。” 护士回答。

“我开个医嘱,你们要确认,要是网络卡住,不就被耽误了?” 赵主任补充。

继续查房,到了7床,一位老太太。赵主任发现她今天的降压药好像和昨天不一样,想确认昨天的用药记录。他打开PDA,点击”历史医嘱”——加载转圈,等了5秒,才出来。”每次查历史记录都这么慢,” 赵主任皱眉,”我们高峰期查房,一个病房20个病人,每个都这么等,时间浪费了。”

李主任跟在后面,默默观察。他意识到:信息科坐在办公室想需求,和在病房现场看医生工作,完全是两回事。他们写PRD(产品需求文档)的时候,脑中的场景是抽象的”医生”在”系统”上操作;实际的场景是:医生被病人家属围着,一手拿PDA一手拿听诊器,护士在喊”3床要换药”,系统如果卡一下,整个节奏就乱了。

3. 互换之后:一场坦诚的对峙

中午,两人在医院食堂边吃边聊。没有记录,没有其他人在场。

赵主任先开口,表情严肃:”你们信息科设计的系统,有几个大问题:”

1. 界面复杂,选项冗余。 我常用的功能要翻好几层菜单,不常用的反而摆在眼前。我们不需要看到所有药品分类,我们需要的是’我的常用药’。

2. 确认弹窗泛滥。 五步确认才保存一条模板?开医嘱时,很多确认是不必要的——我们有医疗规范,系统应该默认我们遵守规范,而不是每一步都质疑我们。

3. 移动端体验差。 PDA信号不稳定,历史数据加载慢,查房时网络不好影响使用。

4. 反馈渠道不畅通。 我们临床提需求,你们要么说做不了,要么拖着;提bug,回复慢。感觉不在一个频道。

李主任听完,没有辩解。他沉思片刻,说:”我也有些发现:”

1. 我们不了解临床节奏。 坐在办公室,我们认为’功能完善’就是好系统;实际上,你们需要的是’快’和’稳’。我们加了太多安全和防错机制,反而降低了效率。

2. 需求变更频繁,我们也头疼。 今天赵主任说要加这个统计,明天张医生说那个报表格式不对。我们改来改去,自己都不知道哪版是正式的。我们需要一个更稳定的需求管理和变更流程。

3. 测试不充分。 我们开发的测试环境,都是模拟数据,没有真实的高峰负荷。一上线,就出性能问题。

4. 沟通方式有问题。 每次开会都是扯皮,没有真正倾听对方。我承认,我有责任,经常觉得临床不切实际。

赵主任点点头:”那我们怎么破局?”

“我觉得,光靠开会吵架不行。我们需要一起工作,共同面对问题。你提的需求,如果说不清场景和痛点,我们无法设计;我们给的技术方案,如果不解释约束,你们会觉得我们推脱。” 李主任说,”这次互换体验是个开始,但还不够。”

“那下一步怎么做?”

“成立一个联合优化小组。我们信息科出两个人,你们医务科出两个人,每周至少两次坐在一起,梳理最高频的临床操作路径,逐条拆解痛点,一起设计方案。方案出来,快速开发,两周内上线验证。不搞大而全,先解决最能提升效率的’关键小事’。”

赵主任表示同意:”好。我加入。但我们要有明确的目标和 deadline。”

4. 三个”断点”与优化计划

接下来的一周,联合小组开了两次会。信息科带来了系统日志和用户行为分析数据:哪些页面点击最多、哪些操作耗时最长、哪些功能使用频率低。医务科带来了临床工作流文档和真实的痛点清单。

他们识别出三个最严重的”断点”:

断点一:医嘱模板配置复杂

– 现状:模板配置界面有7个选项卡,200多个可配置项。医生常用的模板创建需要点击15次以上。

– 问题:临床医生(尤其是高年资副主任以上)不熟悉系统,创建模板时经常求助信息科;模板创建周期长达两三天。

– 影响:新医嘱无法及时上线,延误诊疗。

断点二:保存确认弹窗过多

– 现状:开医嘱保存时,系统默认弹出5个确认框(保存、过敏史、剂量、高危提醒、最终确认)。

– 问题:对于熟练医生,这些弹窗是干扰;对于新医生,弹窗太多反而引起烦躁,可能随手点”确认”而不看内容。

– 影响:操作效率低下,医生情绪抵触。

断点三:移动端查房体验不佳

– 现状:PDA上的历史医嘱查询平均需4-5秒,高峰期可达10秒;部分病房信号弱,指令发送失败率高。

– 问题:查房节奏被打断,医生等待;护士执行医嘱延迟。

– 影响:整体工作效率下降,医患满意度受影响。

针对这三个断点,他们制定了”用户体验优化计划”,核心原则是简化、加速、信任

1. 医嘱模板简化

– 新增”快速模板”模式:只显示10个最常用选项(药品、剂量、频次、疗程),其他高级选项折叠在”更多”里。

– 允许用户自定义”我的模板库”,将常用模板收藏到快捷栏。

– 提供模板导入导出功能,科室之间可以共享常用模板。

2. 确认弹窗智能化降级

– 首次保存必须有严格确认(防误操作)。

– 同一会话内再次保存,确认步骤降级(3步→2步)。

– 高频用户(日均开医嘱>50条)自动启用”极简模式”,只需1步确认。

– 所有确认弹窗增加”不再显示”选项(可设置有效期)。

3. 移动端性能优化

– 历史医嘱查询实现本地缓存:最近3天的医嘱缓存在PDA本地,打开即显示,后台异步刷新。

– 增加离线编辑:信号弱时,医嘱可先保存到本地队列,网络恢复后自动同步。

– 优化网络请求:合并多个API调用,减少请求次数;使用压缩传输,减少流量。

信息科小张评估工时:这些改动不算大,两个开发人员两周内可以完成测试上线。医务科赵主任表示,他们会配合测试,提供真实场景模拟。

5. 两周上线:效果超出预期

两周后的一个周一 morning,优化功能正式上线。

医院没有搞全量切换,而是先在三楼内科病区试点。信息科和医务科的人都守在病区护士站,观察医生使用情况。

第一位入院的李医生,打开PDA,打开医嘱界面。他看到了变化:界面简洁多了,常用药品直接在大按钮上;他试着开了一条”左氧氟沙星 0.5g qd”,点击保存,只弹出一个确认框:”确认开立左氧氟沙星0.5g qd?”——终于不那么烦了。

“这个好,”李医生说,”比以前快多了。”

查房时,他点开历史医嘱,几乎是瞬间就加载出来了。”以前要等好几秒,现在一点击就出来。” 他尝试写了一条新医嘱,网络信号有点弱,系统提示”信号不稳定,已保存到本地,网络恢复后将自动上传”。他没有报错,继续操作其他病人。

护士小陈在治疗室确认医嘱:”老师,今天收到医嘱的速度明显快了。”

试点三天,内科病区的医生提交了小问题反馈(3条),但没有严重bug。性能监控显示:医嘱开立平均时间从原来的45秒降到18秒;移动端查询响应时间从4秒降到0.8秒;确认弹窗数量从平均5个降到1.4个。信息科还收到了一条意想不到的好评:一位高年资主任说,”现在系统比较好用了,我们老同志也能快速上手。”

赵主任在联合小组会上笑了:”没想到,真能见效。”

李主任也松了口气:”临床满意,我们也省心——以前每天处理一堆’为什么这么慢’的投诉。”

一个月后,试点扩展到全院。医务科对信息科的投诉量下降了80%,这是之前谁都没敢想的数字。赵主任在院务会上主动发言:”现在我们内科、外科的系统体验都好了很多。这不是信息科单方面的功劳,是我们双方协作的结果。我们现在不是’你们信息科’,而是’我们医院’——系统好用不好用,每个人都有责任。”

6. 打破部门墙:三个关键时刻

回顾这次跨部门协作的突破,有三个”关键时刻”起到了决定性作用:

关键时刻一:院长的质问

杨院长在办公会上的那一句”你们是不是要学会换位思考”,像一记重锤敲在每个人心上。它没有具体解决方案,但它设定了 tone——对抗不是选项,协作是必须的。如果没有那次会议的压力,赵主任和李主任可能还会继续互相抱怨,不会主动提出互换体验。

关键时刻二:互换体验

互换体验不是走过场,而是真正的沉浸——赵主任在信息科工位实际操作系统配置,李主任穿上白大褂跟着查房。只有亲身体验对方的日常工作,才能感受到那些”痛点”不是无理取闹,而是真实的效率损失。同理心无法通过开会建立,必须亲身感受。

关键时刻三:联合工作小组

建立跨部门的小团队,打破壁垒,每周一起工作。小组成员的KPI里增加了”协作满意度”,双方共同对结果负责。这种机制化的设计,让好的合作关系不是一次性的,而是可持续的。

7. 从”你们”到”我们”:一句称呼的变化

在项目成功的那一天,赵主任在科室微信群发了一条消息:

> “感谢信息科团队的快速响应和专业支持。这次优化让我们临床效率提升明显。我们现在不是’你们信息科’,而是’我们医院’的IT团队。系统好用不好用,每个人都有责任。”

这句话后来成了医院内部流行语。行政那边开会时,也开始说”我们医院的信息化”而不是”你们信息科做的系统”。

李主任感受到最大的变化是:医务科提需求时,不再是”我们要一个报表”(天马行空),而是”我们需要每天了解科室的住院病人数量变化,用于排班,最好能实时,数据源是入院和出院时间”。需求清晰、有场景、有业务价值,信息科才能有效响应。

信息科也改变了沟通方式:不再一上来就说”技术做不到”,而是问”这个需求要解决什么业务问题?”、”您理想中的效果是什么?”、”有没有更简单的方案能达到同样效果?” —— 这种对话方式,减少了对抗,增加了协作。

8. 长效机制:协作不止于一次项目

这次跨部门协作成功后,医院没有止步。他们建立了几个长效机制:

1. 季度”用户体验工作坊”

每季度,信息科和医务科(以及护理部、门诊部)聚在一起,回顾过去三个月的高频投诉和建议,现场演示系统优化方案,收集反馈。工作坊不追求完美,追求”快速迭代”。

2. 临床联络官制度

每个重点科室指派一名”临床联络官”,作为该科室与信息科之间的固定对接人。联络官参加信息科的需求评审会,信息科参加科室的业务学习。这样,信息科能提前了解业务变化,科室能更早知晓系统更新。

3. 需求优先级联合评审

不再是信息科单方面排需求优先级,而是信息科和医务科(轮流主持)共同评审。评审时,需求提出者需要现场演示痛点场景(录屏或口述),然后共同打分(业务价值分、技术复杂度分)。分数高的需求进入开发队列。

4. “谁使用,谁测试”原则

新功能上线前,必须由目标科室的医生/护士进行真实场景测试,信息科观察并记录问题。测试通过率低于90%,不允许上线。

这些机制,让”跨部门协作”从”一次事件”变成”常态”。

9. 周总的观察:客户成功需要内部协作

软佳的周总在一次行业交流会上分享了XX医院的案例:

“很多客户问我们,’你们怎么做好客户成功的?’ 我想说,客户成功不只是供应商的事,更是客户内部的事情。XX医院的这次改进,其实是医院内部的跨部门协作成果。

信息科和医务科原本是对抗的,但通过互换体验和联合工作,他们建立了协作机制。这让我们供应商的工作也变容易了——需求清晰、反馈及时、上线顺利。

所以,我们软佳在服务客户时,不仅关注技术问题,也关注客户的内部协作状态。如果客户内部各部门扯皮,我们再努力也难有成效。因此,我们有时候会建议客户先解决内部协作问题,再来深化系统建设。

真正的客户成功,是客户内部形成’以用户为中心’的协作文化。供应商只是催化剂。”

互动话题

你们医院的信息科和其他科室(如医务科、护理部)关系如何?是否存在沟通壁垒?有没有尝试过”角色互换”或建立联合工作机制来促进协作?欢迎分享你们的经验和看法。

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


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


扫码预约

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

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


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

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

招标现场暗流涌动,结局反转:一次价值导向的销售胜利

四月初,XX省第一人民医院HIS系统升级项目正式招标。

消息一传出,省内五家主流HIS厂商都闻风而动。赵某代表的华通公司来得最早,几乎每两天就来一次,每次不是带点心就是带水果,说是”联络感情”。他还带来了一份看似精美的标书,厚厚一百页,彩印,装帧考究,看起来很高端。

招标会当天,省一院小会议室里坐满了人。除了院方七人评标小组,还有卫健委派来的监督员,以及五家厂商的代表。会议室里弥漫着一种紧张的气氛——这笔680万的大单,省里最大的医院信息化项目,谁都想啃一口。

1. 赵某的表演:华丽外表下的空洞

赵某第一个上台演示。

他西装革履,PPT做得花团锦簇,动画效果炫酷,图表精美。开口闭口都是”行业领先””最佳实践””全国标杆”。台下有些人听得连连点头,特别是财务科王科长,他看着PPT上那些”节省成本30%””效率提升200%”的数据,眼睛都亮了。

但杨院长始终面无表情。她在笔记本上记了几个问题,但一直没有问。

轮到昆明软佳的项目经理小张上台时,所有人以为会是一场碾压的对比——华通的PPT那么花哨,小张的PPT朴素得几乎可以说是简陋,黑白配,没有动画,连公司logo都只有一行小字。

但小张的第一句话就扭转了局面。

他没有急着展示自己的产品,而是问了三个问题:

“各位领导,你们现在最头疼的是什么?是门诊排队太长?是住院管理混乱?还是数据报不上去?”

这个问题一问,现场气氛立刻变了。原先昏昏欲睡的科室主任们,开始交头接耳。

“我们外科最头疼的是手术排程。”外科赵主任说,”经常两个手术撞车,一个医生同时被安排在两台手术上。”

“我们护士站操作太复杂。”护理部陈护士长说,”新护士要培训三个月才会用。”

“我们药房发药慢。”药剂科冯主任说,”患者等太久了投诉很多。”

小张把这些都记下来,然后说:”我们的系统没有很多花哨的功能,但我们解决了这些问题。”

他切到下一页PPT,展示了三张截图:

第一张是手术排程界面的优化——自动冲突检测,一键调整。

第二张是护士站的新手引导——三步完成医嘱确认。

第三张是药房发药的预配功能——挂号时处方就传到药房,患者人还没到,药已经准备好了。

“这些不是我们吹的,”小张说,”都是我们在其他医院实际解决过的问题。我这里有十二个案例,都是和贵院情况类似的医院,你们可以问问他们,我们的系统用得怎么样。”

他把联系方式和案例名称放在大屏幕上。

“我们不会给大家展示花哨的PPT,我们只会解决真实的问题。”

2. 价值呈现:从”第一年成本”到”五年总拥有成本”

杨院长开始认真听。但王科长还在纠结价格:”你们比华通贵60万,凭什么?”

小张没有直接回答,而是在白板上画了一个表格:

| 维度 | 软佳(580万) | 华通(520万) |

|——|————–|————–|

| 合同价(第一年) | 580万 | 520万 |

| 三年运维费 | 包含在合同内 | 280万(每年18%)|

| 培训费 | 两次免费培训 | 额外收费(估算60万)|

| 数据迁移 | 免费 | 收费(估算30万)|

| 五年总拥有成本(估计) | 580万 | 890万 |

“520万只是第一年的价格。”小张说,”从第三年开始,他们每年收18%的维护费,三年就是280万。我们的580万包含四年免费运维。”

王科长计算器按得飞快:”你们四年免费运维值多少钱?”

“按市场价,一年运维费是合同额的15%-20%,四年就是300-400万。”小张说,”但我们不单独卖运维,我们卖的是’系统五年无忧运行’的保证。”

杨院长沉默了。她在算账,但更算的是风险

小张继续:”华通的系统,我们调查过,他们服务的医院平均每两年要有一次较大规模的升级改造,每次升级费用是初始合同的30%-50%。我们的系统设计生命周期是七年,期间只需常规维护。”

“而且,”他调出一份客户名单,”这上面有23家医院,最老的一家是2012年上线的,到现在还在用,每年只做常规升级,没有大修过。平均使用年限5.2年。”

3. 看不见的成本:系统不稳定的代价

“但价格高就是价格高,”刘主任说,”我们要向财政申请,很难批。”

小张知道,单纯讲价值还不够。他需要让客户感受到不选择的代价。

他画了一个流程图:

“`
系统出问题 → 护士操作受阻 → 患者排队时间延长 → 投诉增加

医生效率下降 → 门诊量减少 → 医院收入下降

信息科加班救火 → 人力成本上升 → 员工满意度下降
“`

“这些成本,不会出现在报价单上,但都是医院在承担。”小张说。

他举了个例子:

“假设系统每天出一次小故障(卡顿5分钟),影响200个患者,每人多等3分钟,就是600分钟=10小时的等待。按三甲医院门诊量,这10小时相当于多少就诊量?大概50个号。50个号,平均收费200元,就是1万元。一年365天,就是365万。”

王科长倒吸一口凉气:”这么算…”

“这只是显性成本。”小张继续,”隐性成本更大:患者满意度下降,医院声誉受损,卫健委考核受影响…”

“但你们怎么能保证不出问题?”刘主任问。

“我们不保证不出问题,”小张说,”我们保证问题发生后,4小时内解决,并且不重复发生。”他调出了SLA(服务等级协议)对比:

– 软佳:99.9%可用率,一年最多宕机8.76小时;4小时响应,12小时解决

– 华通:98%可用率,一年最多宕机175小时;24小时响应,48小时解决

“你怎么知道他们的SLA是98%?”杨院长问。

“我有个朋友在华通做售后,他告诉我的。”小张笑,”更重要的是,我可以带您去他们服务的医院问问,一年要报多少次警。”

4. 价格锚定:先高后低的博弈技巧

小张知道,纯粹的”讲价值”还不够。价格谈判,本质是心理战。

他抛出了一个”锚点”:

“其实,我们原来的标准报价是680万。”小张说。

会议室里一片哗然。

“什么?”杨院长吃了一惊。

“但考虑到与贵院的初次合作,我们给了优惠,降到580万。这个价格,在我们服务过的医院里,是最低的。”小张平静地说。

680万是他们 mock 的”天价锚点”。先抛出一个高得离谱的数字,再降到一个看似合理的价格,让客户觉得”占了便宜”。

杨院长笑了:”周总,你这就不厚道了。680万我们想都不敢想。”

“但事实是,我们的服务值这个价。”小张认真地说,”我们不是在卖软件,是在卖’七年无忧运行’的保证。您算一下,580万摊到七年,一年不到83万,一天不到2300元。贵院一年的IT预算多少?占比多少?”

杨院长没接话。她在思考。

小张趁热打铁:”我们软件的生命周期是七年。这七年里,我们提供:

– 四次大版本升级

– 全年7×24小时响应

– 每年两次性能优化

– 免费硬件诊断(如果客户自己买硬件)

– 数据迁移服务(每次升级)

– 安全加固服务

这些,华通都要额外收费。”

5. 价值的拆解:让看不见的变得看得见

小张决定,把”价值”拆开,一项一项跟客户算。

他拿出准备好的”价值清单”:

① 实施服务(价值80万)

– 项目经理常驻2个月

– 8人实施团队

– 数据迁移(含清洗)

– 用户培训(全员,分批次)

– 上线支持(24小时待命一周)

② 运维服务(价值120万/年,四年共480万)

– 7×24小时响应(电话+远程+上门)

– 每月健康巡检

– 每季度性能优化

– 每年一次架构评审

– 应急演练(每年两次)

③ 技术升级(价值150万)

– 四年内所有小版本升级免费

– 两次大版本升级(如V4.0→V5.0)免费

– 新功能模块优先试用权

④ 风险保障(价值无法估量)

– 数据安全(加密传输+加密存储)

– 灾备方案(主备切换演练支持)

– 合规保障(等保测评支持)

– 纠纷调解(如果系统有问题,我们承担责任)

“这些加起来,远超580万。”小张说,”但我们的定价不是’成本加利润’,而是’客户价值’。我们只取其中一部分。”

刘主任问:”那华通为什么不这么算?”

“因为他们卖的是产品,我们卖的是服务。”小张说,”产品有价,服务无价。”

6. 信息科的信任是关键

这时,信息科李主任开口了。

“杨院长,王科长,”他说,”价格不是关键。”

所有人的目光转向他。

李主任说:”我们医院最怕的不是花几百上千万,是怕系统出问题。去年我们有一次数据同步故障,导致住院费用对不上,全院财务加班三天,最后人工核对,花了两个星期。”

他停顿了一下。

“那次事故的直接成本——加班费、误工费——就有三十万。间接成本,比如病人投诉、领导问责,没法算。”

“我们选软佳,一个原因就是他们经历过’真停电’的灾备演练——别人的系统在演示,他们的系统真的用过。这意味着,他们是在用生命做保障。”

李主任看了小张一眼:”软佳报价高,但他们服务过的医院,故障率很低。华通报价低,但他们服务过的医院,每年都有故障报道。”

“多花这六十万,买个’安心’,值。”

杨院长看着李主任,点了点头。

李主任是信息科负责人,他的意见,比谁都重要。

7. 最后的博弈:我们不降价,但我们多送东西

小张知道,客户需要一个”赢”的感觉。

如果什么都不让步,哪怕理由再充分,客户也会觉得”被压服了”。

所以小张说:”这样,价格我们不能再降。但我们可以多送一些服务。”

“什么服务?”

“我们可以:

1. 延长免费运维期,从三年延长到四年(多送一年)

2. 增加一次全员培训(变成三次)

3. 上线后第一个月,派两名工程师常驻医院,随时解决问题

4. 免费为贵院做一次网络优化,确保HIS系统的网络环境没问题

5. 提供一套灾备方案设计(含演练支持)

这些服务,单独买的话,至少50万。”

杨院长和李主任交换了一下眼神。

“这些能写进合同吗?”杨院长问。

“可以,作为补充协议。”

刘主任问:”那总价…”

“还是580万,但我们多送50万的服务。”小张微笑,”相当于变相降价8.6%。”

王科长低头算账:580万 vs 520万,差价60万。软佳送50万服务,实际成本530万,还是比华通贵10万,但多了一年运维和常驻工程师。

“常驻工程师一个月,值多少钱?”王科长问。

“市场价,一个月5万。我们送。”

杨院长笑了:”周总,你这是’买一送一’啊。”

“我们希望贵院用我们的系统,十年都不出事。所以前期投入大一点是值得的。”

8. 合同条款的细节战争

除了价格,合同里还有一堆条款在博弈。

① 违约金条款

医院的草案:”如果系统上线延期,每延期一天,支付合同金额的3%作为违约金,上限为合同总额的50%。”

小张看到时,差点把水喷出来——580万的3%,一天17.4万,十天就174万,远超合同利润。

小张提出”对等责任条款”:

– 双方任何一方违约导致延期,都应向对方支付违约金

– 违约金的计算方式,基于造成的实际损失(而不是固定比例)

– 如果延期由双方共同原因造成,按责任比例分摊

刘主任不同意:”合同白纸黑字,按时上线是你们的义务。”

小张反问:”如果延期是因为贵院的原因呢?比如,你们提供的测试环境不稳定,导致我们无法测试;或者你们需求变更频繁,导致我们返工;或者贵院网络不通,我们集成不了…”

刘主任语塞。

最后折中:

– 仅针对”技术验收延期”(UAT通过后倒推)

– 违约金=延期天数×合同金额×0.3%(原0.5%)

– 上限=合同总额的10%(原50%)

– 如果延期是医院方原因导致,医院方需补偿我方额外成本(按实际工时)

② 阶梯式验收

小张提出”分阶段验收”:

– 技术验收:UAT通过,功能符合需求 → 付90%合同款

– 业务验收:正式上线后7天内,核心业务零重大故障 → 付5%

– 稳定运行验收:上线后30天,系统可用率>99.9% → 付最后5%

如果前两步失败,责任在软佳,整改不额外收费;如果最后一步失败,软佳继续整改,但不触发违约金。

刘主任开始不同意,觉得”分期付款”是软佳不自信。

小张解释:”不是我们不自信,是我们要对齐’成功标准’。如果UAT通过就算成功,那业务上出问题算谁的?分阶段,是对双方的保护。”

杨院长点头:”有道理。”

③ “重大故障”的定义

刘主任加了一个条件:”如果上线后一个月内,出现三次以上’业务中断’(比如门诊挂号失灵、住院无法入出转),除整改外,每发生一次,扣减尾款1%。”

小张问:”什么叫’业务中断’?”

“挂号系统不能用,收费系统不能用,就是业务中断。”

“那如果只是某个功能慢一点,但没有完全不能用,算吗?”

“不算。”

“如果某个科室因为网络问题,不能用,但其他科室能用,算吗?”

“要看影响范围。影响全院,算;影响单个科室,不算。”

小张把它写进条款:

> “业务中断”定义为:影响超过50%用户的系统功能不可用,持续时间超过15分钟。

“这样明确,双方都有数。”

④ 需求变更流程

刘主任最后提了一个要求:”合同里要写清楚,如果需求变更,你们必须配合,不得推诿。”

小张笑了:”刘主任,任何变更,都是有成本的。我们可以配合,但需要有个流程:变更申请→评估影响(工期、成本)→书面签字确认→执行。”

“那是不是我们每次提变更,你们都要加钱?”

“不一定。如果变更很小,不影响工期和成本,可以免费。但如果变更大,增加了工作量,我们需要相应调整合同金额和工期。”

刘主任不同意:”合同价格不能变。”

小张:”那我们就严格按需求来。如果需求之外的变更,我们不做,或者另签补充协议。”

这是底线。

刘主任想了想:”可以,但变更评估要公正,不能你们说多少就多少。”

小张:”评估我们可以一起做,用你的需求文档和我们的工时表。”

9. 签约:价值的胜利

最终结果是:XX医院选择了昆明软佳,580万,额外赠送一年运维和常驻工程师一个月,以及网络优化、灾备方案。

签约那天,华通的赵总也来了,看小张的眼神有点复杂。

签约仪式后,杨院长请所有人喝茶。

她举起茶杯:”今天这个签约,不是价格的胜利,是价值的胜利。我希望,将来回顾这次选择时,我们能说——钱花得值。”

小张举杯:”我保证。”

赵总坐在角落,一言不发,喝完茶就走了。

10. 三个月后:验证的价值

签约后三个月,老周接到李主任电话。

“华通在YY医院的系统,最近频繁出故障,病人都堵在收费处。他们估计要二次招标了。”

老周没说话。

李主任说:”当初选择你们,真的很值。”

老周说:”这不是我们的胜利,是’价值思维’的胜利。”

互动话题

你经历过最成功的一次价格谈判是什么样的?关键是什么?你认为在面对低价竞争时,应该如何向客户传递价值?欢迎在评论区分享你的销售经验和心得。

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


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


扫码预约

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

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


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

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