cloudbeaver创建新的数据库驱动

github下载cloudbeaver的源码

https://github.com/dbeaver/cloudbeaver.git

执行cloudbeaver\deploy\build.bat

该脚本中会同时下载dbeaver等项目的源码

以创建impala数据库连接为例:

  1. 创建目录:cloudbeaver\server\drivers\impala

  2. 目录下创建pom.xml:

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <artifactId>drivers.impala</artifactId>
    <version>1.0.0</version>
    <parent>
    <groupId>io.cloudbeaver</groupId>
    <artifactId>drivers</artifactId>
    <version>1.0.0</version>
    <relativePath>../</relativePath>
    </parent>

    复制代码
     <properties>
         <deps.output.dir>impala</deps.output.dir>
     </properties>
    
     <dependencies>
       <dependency>
         <groupId>com.xxx</groupId>
         <artifactId>impalaJDBC42</artifactId>
         <version>1.0</version>
       </dependency>
     </dependencies>
    </project>
  3. 修改文件:cloudbeaver\server\bundles\io.cloudbeaver.resources.drivers.base\plugin.xml

    <?xml version="1.0" encoding="UTF-8"?> <plugin> <extension point="org.jkiss.dbeaver.resources"> <resource name="drivers/db2"/> <resource name="drivers/db2-jt400"/> <resource name="drivers/duckdb"/> <resource name="drivers/mysql/mysql8"/> <resource name="drivers/mariadb"/> <resource name="drivers/oracle"/> <resource name="drivers/postgresql"/> <resource name="drivers/clickhouse"/> <resource name="drivers/clickhouse_com"/> <resource name="drivers/jaybird"/> <resource name="drivers/h2"/> <resource name="drivers/h2_v2"/> <resource name="drivers/sqlite/xerial"/> <resource name="drivers/mssql/new"/> <resource name="drivers/trino"/> <resource name="drivers/kyuubi"/> <resource name="drivers/databend"/> <resource name="drivers/impala"/> </extension>
    复制代码
     <!-- Bundles  -->
     <extension point="org.jkiss.dbeaver.product.bundles">
         <bundle id="drivers.db2" label="DB2 drivers"/>
         <bundle id="drivers.duckdb" label="DuckDB drivers"/>
         <bundle id="drivers.jt400" label="DB2 iSeries drivers"/>
         <bundle id="drivers.mysql" label="MySQL drivers"/>
         <bundle id="drivers.mariadb" label="MariaDB drivers"/>
         <bundle id="drivers.oracle" label="Oracle drivers"/>
         <bundle id="drivers.postgresql" label="PostgreSQL drivers"/>
         <bundle id="drivers.clickhouse" label="Clickhouse (legacy) drivers"/>
         <bundle id="drivers.clickhouse_com" label="Clickhouse drivers"/>
         <bundle id="drivers.firebird" label="Firebird drivers"/>
         <bundle id="drivers.h2" label="H2 drivers"/>
         <bundle id="drivers.h2_v2" label="H2 v2 drivers"/>
         <bundle id="drivers.sqlite.xerial" label="SQLite drivers"/>
         <bundle id="drivers.mssql.new" label="SQL Server drivers"/>
         <bundle id="drivers.trino" label="Trino drivers"/>
         <bundle id="drivers.kyuubi" label="Apache Kyuubi drivers"/>
         <bundle id="drivers.databend" label="Databend drivers"/>
         <bundle id="drivers.impala" label="impala"/>
     </extension>
    
     <!-- Enabled drivers -->
     <extension point="io.cloudbeaver.driver">
         <driver id="db2:db2"/>
         <driver id="db2_i:db2_iseries"/>
         <driver id="mysql:mysql8"/>
         <driver id="mysql:mariaDB"/>
         <driver id="oracle:oracle_thin"/>
         <driver id="postgresql:postgres-jdbc"/>
         <driver id="jaybird:jaybird"/>
         <driver id="clickhouse:yandex_clickhouse"/>
         <driver id="clickhouse:com_clickhouse"/>
         <driver id="h2:h2_embedded"/>
         <driver id="h2:h2_embedded_v2"/>
         <driver id="sqlite:sqlite_jdbc"/>
         <driver id="sqlite:libsql_jdbc"/>
         <driver id="sqlserver:microsoft"/>
         <driver id="generic:trino_jdbc"/>
         <driver id="generic:duckdb_jdbc"/>
         <driver id="generic:kyuubi_hive"/>
         <driver id="databend:databend"/>
         <driver id="generic:impala"/>
     </extension>
    </plugin>
  4. 修改dbeaver项目中的文件:
    dbeaver\plugins\org.jkiss.dbeaver.ext.generic\plugin.xml

    复制代码
                <driver id="impala"
                         label="impala"
                         icon="icons/impala_icon.png"
                         iconBig="icons/impala_icon_big.png"
                         description="Cloudera Impala. You can download JDBC driver files from https://www.cloudera.com/"
                         class="com.cloudera.impala.jdbc.Driver"
                         sampleURL="jdbc:impala://{host}:{port}/{database}"
                         defaultPort="21050"
                         supportedConfigurationTypes="MANUAL,URL"
                         categories="hadoop"
                         custom="true">
                     <file type="jar" path="drivers/impala" bundle="drivers.impala"/>
                     <parameter name="read-only-data" value="false"/>
                     <parameter name="supports-indexes" value="true"/>
                     <parameter name="all-objects-pattern" value="%"/>
                     <parameter name="quote-reserved-words" value="true"/>
                     <parameter name="omit-schema" value="false"/>
                     <parameter name="supports-table-constraints" value="true"/>
                     <parameter name="schema-filters-enabled" value="false"/>
                     <parameter name="supports-delimiter-in-views" value="true"/>
                     <parameter name="supports-embedded-database-creation" value="true"/>
                     <parameter name="supports-struct-cache" value="true"/>
                     <parameter name="supports-truncate" value="true"/>
                     <parameter name="read-only-meta-data" value="false"/>
                     <parameter name="omit-type-cache" value="false"/>
                     <parameter name="split-procedures-and-functions" value="false"/>
                     <parameter name="supports-stored-code" value="true"/>
                     <parameter name="supports-references" value="true"/>
                     <parameter name="supports-multi-insert" value="false"/>
                     <parameter name="omit-catalog-name" value="false"/>
                     <parameter name="supports-catalog-selection" value="true"/>
                     <parameter name="omit-single-catalog" value="false"/>
                     <parameter name="ddl-drop-column-brackets" value="false"/>
                     <parameter name="omit-single-schema" value="false"/>
                     <parameter name="supports-scroll" value="false"/>
                     <parameter name="omit-catalog" value="false"/>
                     <parameter name="supports-views" value="true"/>
                     <parameter name="script-delimiter" value=";"/>
                     <parameter name="legacy-sql-dialect" value="false"/>
                     <parameter name="script-delimiter-after-query" value="false"/>
                     <parameter name="use-search-string-escape" value="false"/>
                     <parameter name="supports-multiple-results" value="false"/>
                     <parameter name="script-delimiter-after-block" value="false"/>
                     <parameter name="supports-schema-selection" value="true"/>
                     <parameter name="alter-table-add-column" value="false"/>
                     <parameter name="ddl-drop-column-short" value="false"/>
                     <parameter name="supports-limits" value="true"/>
                     <parameter name="supports-select-count" value="true"/>
                     <parameter icon="platform:/plugin/org.jkiss.dbeaver.model/icons/connection/database_icon.png"/>
                 </driver>
  5. 再次执行打包脚本:cloudbeaver\deploy\build.bat

相关推荐
fy1216313 分钟前
Redis 下载与安装 教程 windows版
数据库·windows·redis
F1FJJ24 分钟前
Shield CLI:MySQL 插件 vs phpMyAdmin:轻量 Web 数据库管理工具对比
前端·网络·数据库·网络协议·mysql·容器
果果燕1 小时前
SQLite3数据库查询学习笔记2
数据库·sqlite
2501_908329851 小时前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
认真的薛薛1 小时前
Docker网络模式
linux·运维·数据库·面试·github
Java后端的Ai之路1 小时前
Milvus 向量数据库从入门到精通:AI 时代的“记忆中枢“实战指南(建议收藏!)
数据库·人工智能·milvus·向量数据库·rag
老刘说AI2 小时前
WorkFlow Agent案例:auto_document_agent(文件自动处理)
开发语言·数据库·人工智能·python·神经网络·自然语言处理
脚大江山稳2 小时前
单独为mysql数据库的某个库创建用户
android·数据库·mysql
LSL666_2 小时前
MybatisPlus——通用枚举
数据库·mybatisplus
golang学习记2 小时前
Go 实时批处理:让数据库少挨点打 [特殊字符]
开发语言·数据库·golang