29 Star 291 Fork 78

surive / DBeaver国产化

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README
Apache-2.0

DBeaver 二次开发

由于项目国产化的需要,并且原生DBeaver备份还原功能较弱。

为此基于开源DBeaver 21.3.2 版本进行个性化开发

如果觉得该工具对您有用,请给一个star

基于DBeaver 21.3.2版本增加了以下功能

一、新增功能

1. 内置JDBC驱动

内置了常用数据库驱动,不再需要用户手动下载JDBC驱动,直接创建连接即可使用;方便在无法联网的跳板机环境下使用。

2. SQL记录

记录当前用户执行的所有SQL,方便日后进行复查

3. 国产数据库支持

由于项目国产化的需要,但是国产化数据库连接工具繁多,不方便开发人员日常使用。为此,我们在DBeaver中自编写了国产化数据库插件,方便用户日常使用。当前版本DBeaver支持以下国产数据库,后续将不断支持其他国产数据库:

数据库 是否支持
DM
人大金仓
瀚高
Oscar (神通数据库)
starrocks

4. 多用户支持

原生版本DBeaver多个用户同时使用时存在workspace污染问题,为此我们在eclipse的workspace机制基础上,为DBeaver增加了多用户支持。

5. 备份还原支持

原生版本DBeaver 备份还原功能较弱,我们扩展了DBeaver原生备份还原功能。现已支持以下数据库备份还原:

数据库 备份 还原
MySQL
Oracle
SQL server
Clickhouse
DM
人大金仓
瀚高
神通数据库

6.数据源比较、数据迁移

由于国产化的需要,开发了数据迁移功能。现在支持以下数据库进行迁移:

  1. DM、Kingbase、SQLServer、Oracle、Oscar、PgSQL ==> MySQL
  2. MySQL ==> ClickHouse
  3. Kingbase、MySQL、Oracle、Oscar、SQLServer ==> DM
  4. MySQL、Oracle、SQLServer ==> Kingbase
  5. MySQL 、Oracle ==> SQLServer
  6. DM、MySQL、Oscar、SQLServer ==> Oracle
  7. DM、MySQL、Oracle、SQLServer ==> Oscar
  8. MySQL、Oracle ==> SQLite

7. 安全模式

新增了安全模式,当数据库支持开启安全模式时。用户在执行Update、Delete 语句时将会提示用户,并且会将删除或者更新的数据放到数据回收站中。如果需要恢复数据时直接在数据回收站中进行操作即可。

8. 其他新增功能

  1. 表DDL转换,支持MySQL 表DDL语句转换成其他常用数据库SQL语句,后续将继续支持其他数据库
  2. 测试数据生成器,能够自动生成测试数据并插入表中

9. DBeaver插件机制

  1. 新增MySQL binlog解析插件,可以进行binlog的解析,后续将继续支持其他插件

二、操作文档

新增功能的操作文档请看此处:wiki

三、下载使用

当前提供以下平台的DBeaver安装包:Windows、Linux、macos。

Windows下安装使用建议您直接下载exe安装包,exe安装包中包含了数据库备份还原组件;如果您使用zip包进行安装将无法使用数据库备份还原功能。

百度网盘下载地址

链接:https://pan.baidu.com/s/1wm2apJ73Y3_0gwTUuJZulA 提取码:6666

文件服务器下载地址:

文件服务器上下载: http://124.222.82.34:8848/ 用户名/密码: ysk/123456

四、建议

如果您在使用过程中有什么问题或者建议都可在Issues中提出,当然如果您觉得这个工具对您有所帮助请给一个star。

五、开发

如果您也需要二次开发DBeaver,可以看一下我写的文档:DBeaver 开发文档。 由于我个人不是做eclipse rcp出身,对于rcp框架本身并不太熟悉,所以文档本身着重于在DBeaver的基础上去进行一些功能扩展,例如:编写新插件、在原有插件上扩展新功能等;如果您对rcp框架感兴趣,可以看一下rcp 官方文档以及rcp 教程

由于是下班更新,文档更新可能会有点慢(如果被优化了可能就快了:joy:)

Apache License Version 2.0, January 2004 http://www.apache.org/licenses/ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 1. Definitions. "License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document. "Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License. "Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity. "You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License. "Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files. "Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types. "Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below). "Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof. "Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution." "Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work. 2. Grant of Copyright License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form. 3. Grant of Patent License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed. 4. Redistribution. You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions: (a) You must give any other recipients of the Work or Derivative Works a copy of this License; and (b) You must cause any modified files to carry prominent notices stating that You changed the files; and (c) You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and (d) If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License. You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License. 5. Submission of Contributions. Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions. 6. Trademarks. This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file. 7. Disclaimer of Warranty. Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License. 8. Limitation of Liability. In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages. 9. Accepting Warranty or Additional Liability. While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability. END OF TERMS AND CONDITIONS APPENDIX: How to apply the Apache License to your work. To apply the Apache License to your work, attach the following boilerplate notice, with the fields enclosed by brackets "[]" replaced with your own identifying information. (Don't include the brackets!) The text should be enclosed in the appropriate comment syntax for the file format. We also recommend that a file or class name and description of purpose be included on the same "printed page" as the copyright notice for easier identification within third-party archives. Copyright [yyyy] [name of copyright owner] Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

简介

在原生DBeaver的基础上,支持了DM、Kingbase、瀚高、神通等国产数据库。并且增加了数据库备份还原以及数据迁移等功能。 展开 收起
Java 等 5 种语言
Apache-2.0
取消

发行版 (4)

全部

贡献者

全部

近期动态

加载更多
不能加载更多了
Java
1
https://gitee.com/surive/DBeaverRelease.git
git@gitee.com:surive/DBeaverRelease.git
surive
DBeaverRelease
DBeaver国产化
master

搜索帮助