DoltgreSQL:版本控制的PostgreSQL数据库
项目介绍
DoltgreSQL(又名Doltgres)是Dolt的一个PostgreSQL风格版本,目前处于预阿尔法发布阶段。它旨在将类似于Git的日志、差异、分支和合并功能带到你的PostgreSQL数据库模式和数据中。不同于使用MySQL客户端和MySQL SQL,用户可以利用PostgreSQL客户端与Doltgres交互,并使用PostgreSQL SQL。此项目从Dolt——世界上首个版本控制的SQL数据库发展而来,特别针对想要在数据库层面实现版本控制的需求。
快速启动
安装与设置
首先,下载DoltgreSQL的最新版本。确保你的系统已安装PostgreSQL 15或更高版本。如果你使用的是macOS并且通过Homebrew安装PostgreSQL,可能需要手动添加路径:
export PATH="/opt/homebrew/opt/postgresql@15/bin:$PATH"
然后,运行Doltgres初始化数据库环境:
doltgres
这会在默认目录~/doltgres/databases
创建一个名为doltgres的数据库及用户。你可以通过指定--data-dir
或调整DOLTGRES_DATA_DIR
环境变量来改变存储位置。
连接与基本操作
打开一个新的终端并连接到刚创建的数据库:
psql -h localhost -U doltgres
接下来,在Doltgres中创建示例数据库和表:
create database getting_started;
\c getting_started;
create table employees (id int8, last_name text, first_name text, primary key(id));
create table teams (id int8, team_name text, primary key(id));
create table employees_teams(team_id int8, employee_id int8, primary key(team_id, employee_id), foreign key(team_id) references teams(id), foreign key(employee_id) references employees(id));
进行初次提交以体验版本控制特性:
select * from dolt_status;
call dolt_add('teams', 'employees', 'employees_teams');
call dolt_commit('-m', 'Initial schema created');
select * from dolt_log;
应用案例与最佳实践
虽然Doltgres尚处于实验性阶段,但它适用于那些希望对PostgreSQL数据库进行版本控制的场景。一个典型的使用案例是在团队间协作开发数据库结构和初始数据时,保证数据变更的可追溯性和一致性。最佳实践包括频繁地提交数据库变化,使用清晰的提交信息记录每一次更改的目的,以及定期备份数据。
典型生态项目
由于Doltgres本身就是一个特殊的数据库解决方案,其生态系统围绕版本控制的数据库管理展开。尽管目前没有详细列出具体的“典型生态项目”,但它的存在扩展了数据库管理工具的边界,鼓励开发者探索如何结合其他DevOps工具链,比如CI/CD流程中的数据库版本自动化管理。随着项目成熟,可能会出现更多集成案例,如与GitLab CI/CD或Jenkins的自动化部署结合,或者与数据仓库迁移工具的协同使用,提升数据治理的质量和效率。
请注意,上述信息基于提供的链接资料编撰,实际使用时应参考最新的项目文档和社区更新。
- QQwen3-Next-80B-A3B-InstructQwen3-Next-80B-A3B-Instruct 是一款支持超长上下文(最高 256K tokens)、具备高效推理与卓越性能的指令微调大模型00
- QQwen3-Next-80B-A3B-ThinkingQwen3-Next-80B-A3B-Thinking 在复杂推理和强化学习任务中超越 30B–32B 同类模型,并在多项基准测试中优于 Gemini-2.5-Flash-Thinking00
GitCode-文心大模型-智源研究院AI应用开发大赛
GitCode&文心大模型&智源研究院强强联合,发起的AI应用开发大赛;总奖池8W,单人最高可得价值3W奖励。快来参加吧~0108DuiLib_Ultimate
DuiLib_Ultimate是duilib库的增强拓展版,库修复了大量用户在开发使用中反馈的Bug,新增了更加贴近产品开发需求的功能,并持续维护更新。C++03GitCode百大开源项目
GitCode百大计划旨在表彰GitCode平台上积极推动项目社区化,拥有广泛影响力的G-Star项目,入选项目不仅代表了GitCode开源生态的蓬勃发展,也反映了当下开源行业的发展趋势。08- HHunyuan-MT-7B腾讯混元翻译模型主要支持33种语言间的互译,包括中国五种少数民族语言。00
GOT-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).Dockerfile03
- PpathwayPathway is an open framework for high-throughput and low-latency real-time data processing.Python00
- Dd2l-zh《动手学深度学习》:面向中文读者、能运行、可讨论。中英文版被70多个国家的500多所大学用于教学。Python011
热门内容推荐
最新内容推荐
项目优选









