推荐开源项目:sql-formatter —— 精致的SQL格式化工具
2024-06-08 07:24:34作者:何将鹤
在数据库开发和管理中,保持SQL代码的整洁与规范至关重要,它能提高团队协作效率,并使得代码易于理解和维护。今天,我们向您推荐一款纯Java实现的SQL格式化库——sql-formatter,它能帮您轻松地将凌乱的SQL语句转化为美观易读的代码块。
1、项目介绍
sql-formatter是基于Java标准库开发的轻量级开源项目,无需任何额外依赖。它受到ZeroTurnaround的知名SQL格式化器启发,提供了一种简单而高效的方式来整理SQL语句,使其符合编码规范。此外,它还提供了在线演示版,方便开发者直接试用(Demo)。
2、项目技术分析
该项目使用纯Java编写,没有引入外部库,保证了其小巧且易于集成。它支持多种SQL方言,包括但不限于Standard SQL、MySQL、PostgreSQL、Oracle PL/SQL等。通过Dialect类,您可以轻松切换不同的语法环境。
sql-formatter不仅提供基础的格式化功能,还允许自定义配置,如缩进风格、大小写转换、查询之间的行间距以及列的最大长度。此外,它还支持占位符替换,能够处理命名或索引型参数。
3、项目及技术应用场景
- 开发工具:集成到IDEA、VSCode等开发环境中,实时美化SQL代码。
- 数据库脚本整理:大量手写或复制的SQL脚本需要规范化处理时。
- 代码审查:确保团队成员提交的SQL代码符合统一的格式规范。
- 自动化测试:在自动化测试框架中,自动格式化生成的SQL语句。
- 服务器端API:通过网络接口提供在线SQL格式化服务。
4、项目特点
- 无依赖:仅使用Java标准库,便于集成。
- 多语言支持:覆盖多种主流SQL方言,满足各种数据库系统的需求。
- 高度可配置:提供FormatConfig构建器以定制您的格式化规则。
- 动态扩展:允许自定义添加运算符,适应项目特有的语法。
- 参数替换:支持通过列表或映射进行参数化的SQL格式化。
通过上述特性,sql-formatter成为了开发人员在处理SQL代码时的强大助手,无论是日常开发还是自动化任务,都能展现出高效的代码组织能力。
要开始使用这个项目,只需按照README中的指引添加对应的Maven或Gradle依赖,然后调用SqlFormatter提供的API即可。赶快将sql-formatter纳入您的开发工具箱,享受它带来的便利吧!
// Maven
<dependency>
<groupId>com.github.vertical-blank</groupId>
<artifactId>sql-formatter</artifactId>
<version>2.0.5</version>
</dependency>
// Gradle
implementation 'com.github.vertical-blank:sql-formatter:2.0.5'
在代码中尝试一下:
SqlFormatter.format("SELECT * FROM table1");
简短的一行代码,即能将SQL世界变得更美好。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0216
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
uni-appA cross-platform framework using Vue.jsJavaScript08
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
465
Ascend Extension for PyTorch
Python
758
968
昇腾LLM分布式训练框架
Python
185
231
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
698
1.4 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
878
2.03 K
暂无描述
Dockerfile
780
5.08 K
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
70
22
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
2.08 K
216