Liquibase 中 endDelimiter 参数在 PostgreSQL 函数定义中的使用问题分析
问题背景
Liquibase 是一款流行的数据库变更管理工具,它允许开发者通过声明式的方式管理数据库变更。在 Liquibase 4.29.2 版本中,用户报告了一个关于 endDelimiter
参数的问题,特别是在 PostgreSQL 函数定义中使用 $$
作为分隔符时出现了解析错误。
问题现象
用户在 PostgreSQL 数据库中使用 Liquibase 部署包含 PL/pgSQL 函数的变更集时,遇到了语法错误。具体表现为:
<sql endDelimiter="$$">
create function foo() returns trigger AS $$
begin
...
end;
$$ language plpgsql;
</sql>
执行时会报错:
ERROR: syntax error at end of input [Failed SQL: (0) create function A() returns trigger AS]
技术分析
历史行为
在 Liquibase 4.27.0 及更早版本中,endDelimiter="$$"
能够正确解析 PostgreSQL 函数定义。整个函数体被当作一个完整的语句执行。
4.28.0 版本后的变化
从 Liquibase 4.28.0 开始,解析器将 $$
视为语句分隔符,导致函数定义被拆分成多个部分:
- 第一部分:
create function foo() returns trigger AS
- 第二部分:
begin
...
end;
- 第三部分:
language plpgsql;
这种拆分导致第一个语句不完整,从而引发语法错误。
解决方案
推荐方案
使用不冲突的分隔符替代 $$
,例如 $END$
:
<sql endDelimiter="$END$">
create function foo() returns trigger AS $$
begin
...
end;
$$ language plpgsql;
$END$
其他注意事项
-
向后兼容性:这个变化影响了现有使用
$$
作为分隔符的变更集,需要开发者手动更新。 -
文档建议:官方文档应明确说明在 PostgreSQL 函数定义中使用
endDelimiter
时的最佳实践。 -
测试策略:升级 Liquibase 版本后,应特别测试包含函数定义的变更集。
技术原理
Liquibase 的 SQL 解析器在处理 endDelimiter
参数时,会扫描整个 SQL 内容寻找匹配的分隔符。当使用 $$
作为分隔符时,它与 PostgreSQL 函数体标记冲突,导致解析器错误地将函数体内的 $$
也识别为语句分隔符。
最佳实践建议
-
避免在 PostgreSQL 函数定义中使用
$$
作为 Liquibase 的endDelimiter
。 -
考虑使用更独特的分隔符,如
$END$
或//
,减少与 SQL 内容冲突的可能性。 -
对于复杂的 SQL 对象(如函数、存储过程),建议将其放在单独的文件中,通过
<sqlFile>
标签引用。 -
升级 Liquibase 版本时,应全面测试数据库变更脚本,特别是包含复杂 SQL 对象的部分。
总结
Liquibase 4.28.0 版本对 endDelimiter
的处理逻辑进行了改进,这导致了一些向后兼容性问题。开发者需要了解这一变化,并相应调整他们的变更集定义。通过使用不冲突的分隔符和遵循最佳实践,可以确保数据库变更的顺利执行。
HunyuanImage-3.0
HunyuanImage-3.0 统一多模态理解与生成,基于自回归框架,实现文本生成图像,性能媲美或超越领先闭源模型00- DDeepSeek-V3.2-ExpDeepSeek-V3.2-Exp是DeepSeek推出的实验性模型,基于V3.1-Terminus架构,创新引入DeepSeek Sparse Attention稀疏注意力机制,在保持模型输出质量的同时,大幅提升长文本场景下的训练与推理效率。该模型在MMLU-Pro、GPQA-Diamond等多领域公开基准测试中表现与V3.1-Terminus相当,支持HuggingFace、SGLang、vLLM等多种本地运行方式,开源内核设计便于研究,采用MIT许可证。【此简介由AI生成】Python00
GitCode-文心大模型-智源研究院AI应用开发大赛
GitCode&文心大模型&智源研究院强强联合,发起的AI应用开发大赛;总奖池8W,单人最高可得价值3W奖励。快来参加吧~0370Hunyuan3D-Part
腾讯混元3D-Part00ops-transformer
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。C++0102AI内容魔方
AI内容专区,汇集全球AI开源项目,集结模块、可组合的内容,致力于分享、交流。02Spark-Chemistry-X1-13B
科大讯飞星火化学-X1-13B (iFLYTEK Spark Chemistry-X1-13B) 是一款专为化学领域优化的大语言模型。它由星火-X1 (Spark-X1) 基础模型微调而来,在化学知识问答、分子性质预测、化学名称转换和科学推理方面展现出强大的能力,同时保持了强大的通用语言理解与生成能力。Python00GOT-OCR-2.0-hf
阶跃星辰StepFun推出的GOT-OCR-2.0-hf是一款强大的多语言OCR开源模型,支持从普通文档到复杂场景的文字识别。它能精准处理表格、图表、数学公式、几何图形甚至乐谱等特殊内容,输出结果可通过第三方工具渲染成多种格式。模型支持1024×1024高分辨率输入,具备多页批量处理、动态分块识别和交互式区域选择等创新功能,用户可通过坐标或颜色指定识别区域。基于Apache 2.0协议开源,提供Hugging Face演示和完整代码,适用于学术研究到工业应用的广泛场景,为OCR领域带来突破性解决方案。00- HHowToCook程序员在家做饭方法指南。Programmer's guide about how to cook at home (Chinese only).Dockerfile09
- PpathwayPathway is an open framework for high-throughput and low-latency real-time data processing.Python00
热门内容推荐
最新内容推荐
项目优选









