探索代码的奇妙旅程:JQL——SQL在Java源码中的应用
2024-06-10 17:51:24作者:温玫谨Lighthearted
提示:本项目尚处于早期阶段,旨在评估和获取反馈。尝试一下,并告诉我们你的想法吧!
1、项目介绍
JQL(Java Query Language)是一个创新的开源工具,它允许开发者以SQL查询的方式来探索和理解Java源代码。想象一下,你可以像查找数据库记录一样,轻松地找到那些没有单元测试的类,或者查询最长的类名,甚至是寻找接口中拥有超过20个方法的情况。
2、项目技术分析
JQL的工作原理是将Java代码库转换为一个关系型数据库,然后通过标准SQL进行查询。其核心模型包括了诸如类型(Type)、类(Class)、接口(Interface)、方法(Method)等实体,以及它们之间的关系。例如,一个类可以有多个方法,而一个方法又属于一个特定的类型或接口。
实体与关系
表示实体图
显示了这些实体间的关系
详细的数据库模式描述可在项目wiki中查看。
3、项目及技术应用场景
JQL适用于以下场景:
- 代码质量检查:通过查询确定代码是否符合最佳实践,如无测试的类、过长的类名等。
- 代码审计:在接手新项目时,快速了解代码结构和可能的问题点。
- 重构准备:找出过度复杂的接口和类,以便进行重构。
- 团队教学:帮助新人快速理解和掌握项目代码结构。
4、项目特点
- 直观易用:使用熟悉的SQL语言,降低了学习成本。
- 灵活多变:任何关于代码结构的问题,都可以转化为SQL查询来解答。
- 开箱即用:提供单一可执行jar文件,简单命令即可完成代码分析。
- Maven集成:对于Maven项目,可以通过插件直接进行集成。
如何开始?
运行以下命令即可创建数据库并分析指定的Java项目:
java -jar jql-core-0.1.jar /path/to/project/to/analyse /path/to/database/directory
对于Maven项目,只需在根目录下执行:
mvn io.github.benas:jql-maven-plugin:index
然后,使用您喜欢的SQL客户端打开生成的jql.db文件,开始编写您的查询吧!
完整的启动指南见这里。
贡献与支持
欢迎任何形式的贡献,无论是建议改进关系模型,还是发现无法回答的问题。请尝试使用JQL分析代码库,或者下载预处理的数据库样本,编写查询,如果遇到问题,请打开issue分享你的发现。
JQL感谢JavaParser提供的代码解析支持,以及Sqlite提供的数据库服务。
许可证
JQL遵循MIT许可证:
MIT License
Copyright (c) 2016, Mahmoud Ben Hassine (mahmoud.benhassine@icloud.com)
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
准备好开启你的代码探索之旅了吗?JQL期待你的加入!
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
热门内容推荐
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
531
3.74 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
336
178
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
886
596
Ascend Extension for PyTorch
Python
340
403
暂无简介
Dart
772
191
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
986
247
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
416
4.21 K
React Native鸿蒙化仓库
JavaScript
303
355