Proxool 连接池连接 seekdb 示例程序
本文将介绍如何使用 Proxool 连接池、MySQL Connector/J 和 seekdb 构建一个应用程序,实现基本的数据库操作,包括创建表、插入、删除、更新和查询数据等。
点击下载 proxool-mysql-client 示例工程
前提条件
-
您已安装 seekdb。
-
您已安装 JDK 1.8 和 Maven。
-
您已安装 IntelliJ IDEA。
信息本文档运行代码使用的工具是 IntelliJ IDEA Community Edition 2021.3.2 版本,您也可以根据个人喜好选择适合自己的工具运行的示例代码。
操作步骤
本文中给出的操作步骤是在 Windows 环境下使用 IntelliJ IDEA Community Edition 2021.3.2 编译和运行该项目的步骤。如果您使用的是其他操作系统环境或编译器,那么操作步骤可能会略有不同。
- 将
proxool-mysql-client项目导入到 IntelliJ IDEA 中。 - 获取 seekdb URL。
- 修改
proxool-mysql-client项目中的数据库连接信息。 - 运行
proxool-mysql-client项目。
步骤一:将 proxool-mysql-client 项目导入到 IntelliJ IDEA 中
-
打开 IntelliJ IDEA。
-
在欢迎界面上,点击 Open 选项,导航到您的项目目录,选择项目的根目录,点击 OK。

-
IntelliJ IDEA 会自动检测项目类型并加载项目。
信息当使用 IntelliJ IDEA 导入 Maven 项目时,IntelliJ IDEA 会自动检测项目中的
pom.xml文件,并根据文件中描述的依赖关系自动下载所需的依赖库,并将它们添加到项目中。
-
(可选)手动导入未解析的依赖项。
如果
pom.xml文件中对应的依赖项都自动导入到了项目中,请忽略此步骤。通过 IntelliJ IDEA 的 Sync 窗口的提示,可以发现
proxool-cglib和proxool依赖项未解析。proxool-mysql-client项目根目录下的lib的文件夹中有proxool-cglib和proxool的jar文件,将其添加到项目,步骤如下:- 在 IntelliJ IDEA 中,点击 File -> Project Structure 进入项目结构设置。
- 在左侧面板中,选择 Modules。
- 在右侧的模块列表中,选择 Dependencies 选项卡,点击此页面上的 + 图标,选择 JARs or directories。
- 在弹出的对话框中,导航到存放
jar文件的lib目录,选中jar文件,点击 OK。 - 在 Dependencies 选项卡下,会看到新加入的
jar文件出现在列表中。 - 点击 Apply 或 OK 保存更改。

步骤二:获取 seekdb URL
-
联系 seekdb 部署人员或者管理员获取相应的数据库连接串。
示例如下:
mysql -hxxx.xxx.xxx.xxx -P2881 -uroot -p****** -Dtest -A更多连接串的信息,请参见 通过 MySQL 客户端连接 seekdb。
-
根据 seekdb 连接串信息填写下面 URL 的对应信息。
jdbc:mysql://$host:$port/$database_name?user=$user_name&password=$password参数说明:
$host:提供 seekdb 的连接 IP。应该被实际的 IP 替换,也可以使用本地 IP 及 127.0.0.1。$port:提供 seekdb 接端口。应该被实际的端口替换,默认是 2881,在部署 seekdb 时可自定义。$database_name:需要访问的数据库名称。user_name:提供连接账户。格式:用户名。password:提供账户密码。
更多有关 MySQL Connector/J 连接属性信息,请参见 Configuration Properties。
示例如下:
jdbc:mysql://xxx.xxx.xxx.xxx:2881/test?user=root&password=******
步骤三:修改 proxool-mysql-client 项目中的数据库连接信息
根据 步骤二:获取 seekdb URL 中获取的信息修改文件 proxool-mysql-client/src/main/resources/db.properties 中的数据库连接信息。
示例如下:
- seekdb 地址为
xxx.xxx.xxx.xxx。 - 访问端口使用的是 2881。
- 需要访问的数据库名称为
test。 - 连接账户是
root。 - 密码是
******。
代码如下:
...
jdbc-1.proxool.driver-url=jdbc:mysql://xxx.xxx.xxx.xxx:2881/test?useSSL=false
jdbc-1.user=root
jdbc-1.password=******
...
步骤四:运行 proxool-mysql-client 项目
-
在项目导航栏中,找到并展开 src/main/java/com.example 目录。
-
右键点击 Main 文件,选择 Run 'Main.main()'。
-
IntelliJ IDEA 会自动编译和运行该项目,并在运行面板中显示输出结果。

-
也可以在 seekdb 中执行以下 SQL 语句查看结果。
SELECT * FROM test.test_proxool;返回结果如下:
+------+---------------+
| c1 | c2 |
+------+---------------+
| 6 | test_update |
| 7 | test_insert7 |
| 8 | test_insert8 |
| 9 | test_insert9 |
| 10 | test_insert10 |
+------+---------------+
5 rows in set
项目代码介绍
点击 proxool-mysql-client 下载项目代码,是一个名称为 proxool-mysql-client.zip 的压缩包。
解压后,得到一个名为 proxool-mysql-client 的文件夹。目录结构如下所示:
proxool-mysql-client
├── lib
│ ├── proxool-0.9.1.jar
│ └── proxool-cglib.jar
├── src
│ └── main
│ ├── java
│ │ └── com
│ │ └── example
│ │ └── Main.java
│ └── resources
│ └── db.properties
└── pom.xml
文件说明:
lib:存放项目所需的依赖库文件。proxool-0.9.1.jar:Proxool 连接池库文件。proxool-cglib.jar:用于支持 Proxool 连接池的 CGLib 库文件。src:源代码根目录。main:主代码目录,包含应用程序的主要逻辑。java:Java 源代码目录。com:Java 包目录。example:示例项目的包目录。Main.java:主类程序示例文件,包含创建表、插入、删除、更新和查询数据等逻辑。resources:资源文件目录,包含配置文件等。db.properties:连接池的配置文件,包含了数据库连接的相关参数。pom.xml:Maven 项目的配置文件,用于管理项目的依赖和构建设置。
pom.xml 代码介绍
pom.xml 文件是 Maven 项目的配置文件,定义了项目的依赖项、插件和构建规则等信息。Maven 是一个 Java 项目管理工具,可以自动下载依赖项、编译和打包项目等操作。
本文 pom.xml 文件的代码主要包括以下几个部分:
-
文件声明语句。
声明本文件是一个 XML 文件,使用的 XML 版本是
1.0,字符编码方式是UTF-8。代码如下:
<?xml version="1.0" encoding="UTF-8"?> -
配置 POM 的命名空间和 POM 模型版本。
- 通过
xmlns指定 POM 的命名空间为http://maven.apache.org/POM/4.0.0。 - 通过
xmlns:xsi指定 XML 命名空间http://www.w3.org/2001/XMLSchema-instance。 - 通过
xsi:schemaLocation指定 POM 的命名空间为http://maven.apache.org/POM/4.0.0和 POM 的 XSD 文件的位置为http://maven.apache.org/xsd/maven-4.0.0.xsd。 - 通过
<modelVersion>元素指定了该 POM 文件使用的 POM 模型版本为4.0.0。
代码如下:
<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>
<!-- 其他配置 -->
</project> - 通过
-
配置基本信息。
- 通过
<groupId>指定项目所属组织为com.example。 - 通过
<artifactId>指定项目的名称为proxool-mysql-client。 - 通过
<version>项目的版本号为1.0-SNAPSHOT。
代码如下:
<groupId>com.example</groupId>
<artifactId>proxool-mysql-client</artifactId>
<version>1.0-SNAPSHOT</version> - 通过
-
配置项目源文件的属性。
指定 Maven 的编译器插件为
maven-compiler-plugin,并设置了源代码和目标 Java 版本都为 8。这意味着项目的源代码使用 Java 8 特性编写,且编译后的字节码也将兼容 Java 8 运行时环境。这样设置可以确保项目在编译和运行时能够正确地处理 Java 8 的语法和特性。信息Java 1.8 和 Java 8 是同一个版本的不同命名方式。
代码如下:
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>8</source>
<target>8</target>
</configuration>
</plugin>
</plugins>
</build> -
配置项目所依赖组件。
通过
<dependency>定义依赖项:-
添加
mysql-connector-java库,用于连接和操作数据库:- 通过
<groupId>指定依赖项所属的组织为mysql。 - 通过
<artifactId>指定依赖项的名称为mysql-connector-java。 - 通过
<version>指定依赖项的版本号为5.1.47。
代码如下:
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency> - 通过
-
添加
proxool-cglib依赖库,用于支持 Proxool 连接池的 CGLib 库:- 通过
<groupId>指定依赖项所属的组织为proxool。 - 通过
<artifactId>指定依赖项的名称为proxool-cglib。 - 通过
<version>指定依赖项的版本号为0.9.1。
代码如下:
<dependency>
<groupId>proxool</groupId>
<artifactId>proxool-cglib</artifactId>
<version>0.9.1</version>
</dependency> - 通过
-
添加
proxool依赖库,Proxool 连接池的核心库:- 通过
<groupId>指定依赖项所属的组织为proxool
- 通过
-