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

在弹出的 Open File or Project 窗口中,选择对应的项目文件,单击 OK 完成项目文件导入。
IntelliJ IDEA 将会自动识别项目中的各类文件,并在 Project 工具窗口中,可以查看项目的目录结构、文件列表、模块列表、依赖关系等信息。Project 工具窗口通常位于 IntelliJ IDEA 界面的最左侧,默认情况下是打开的。如果 Project 工具窗口被关闭了,可以通过点击菜单栏中的 View > Tool Windows > Project 或者使用快捷键 Alt + 1 来重新打开它。
说明当使用 IntelliJ IDEA 导入项目时,IntelliJ IDEA 会自动检测项目中的 pom.xml 文件,并根据文件中描述的依赖关系自动下载所需的依赖库,并将它们添加到项目中。
查看项目情况。

步骤二:获取 OceanBase 数据库连接信息
联系 OceanBase 数据库部署人员或者管理员获取相应的数据库连接串。
obclient -hxx.xx.xx.xx -P3306 -uroot -p**** -A根据已部署的 OceanBase 数据库填写下面 URL 的对应信息。
说明在
application.properties文件中需要这里的 URL 信息。jdbc:oceanbase://host:port/schema_name?user=$user_name&password=$password&characterEncoding=UTF-8参数说明:
host:OceanBase 数据库连接的域名。port:OceanBase 数据库连接端口,MySQL 模式租户默认是 3306。schema_name:需要访问的 Schema 名称。user_name:租户的连接账号。password:提供账户密码。characterEncoding:支持数据库 URL 选项的字符编码。默认值:utf8。
更多 URL 参数说明信息,请参见 数据库 URL。
步骤三:修改tomcat-mysql-client项目中的数据库连接信息
根据 步骤二:获取 OceanBase 数据库连接信息 中的信息修改application.properties文件中的数据库连接信息。
示例如下:
数据库驱动的名称为:
com.oceanbase.jdbc.DriverOBServer 节点的 IP 地址为
xxx.xxx.xxx.xxx。访问端口使用的是 3306。
需要访问的 Schema 名称为
TEST。租户的连接账户是
root。密码是
******。
示例代码如下:
#Apache Commons DBCP2 Connection Pool
#Database Connection Pool Driver Class Name
db.app.pool.driverClassName=com.oceanbase.jdbc.Driver
#Database URL
db.app.pool.url=jdbc:oceanbase://xxx.xxx.xxx.xxx/TEST?characterEncoding=UTF-8
#Database username
db.app.pool.username=root
#Database password
db.app.pool.password=******
#Initial size of connection pool
db.app.pool.initialSize=3
#Maximum number of connections in the connection pool
db.app.pool.maxTotal=10
#Maximum number of idle connections in the connection pool
db.app.pool.maxIdle=20
#Minimum number of idle connections in the connection pool
db.app.pool.minIdle=5
#Maximum wait time for obtaining connections (in milliseconds)
db.app.pool.maxWaitMillis=5000
#Verify the connection's query statement
db.app.pool.validationQuery=select 1 from dual步骤四:搭建tomcat-mysql-client项目的 Tomcat 运行环境
下载 Tomcat 8.5.95 版本。
在 Apache Tomcat 官网 下载 Tomcat 8.5.95 版本的压缩包。解压下载的压缩包到您想要安装 Tomcat 的目录。
在 IDEA 中配置 Tomcat。
打开 IntelliJ IDEA,进入 File 菜单,选择 Settings > Plugins。在 Settings 窗口中间的搜索框中搜索 Smart Tomcat,下载后选择 Apply,此时 Settings 窗口左侧最下方跳出 Tomcat Server 页签,进入 Tomcat Server 页签,单击右侧的+按钮,选择您解压缩的 Tomcat 目录,单击 Apply 后单击 OK,完成配置。

创建 Tomcat 运行配置。
在 IDEA 的顶部工具栏中,选择 Run > Edit Configurations。在 Run/Debug Configurations 窗口中,单击+按钮,选择 Tomcat Server,填写运行服务器名称 Name,在 Configuration 选择框中选择 Tomcat sever 为您安装的版本,修改 Context path 值为
/,填写 SSL port 值为8080。在 Before launch 选择框中,单击+,选择 Launch Web Browser。单击 Edit 填写 URL 为http://localhost:8080/hello/getData。单击 Apply 后单击 OK,完成配置。
运行 Tomcat 服务器。
在 IDEA 的顶部工具栏中,选择您刚刚创建的 Tomcat 运行配置。点击运行按钮 绿色三角形 启动 Tomcat 服务器。您可以在 IDEA 的 Run 窗口中查看 Tomcat 服务器的启动日志。
步骤五:运行tomcat-mysql-client项目
运行路径。
在 IDEA 的顶部工具栏中,选择您刚刚创建的 Tomcat 运行配置。点击运行按钮绿色三角形启动 Tomcat 服务器。在谷歌或 IE 浏览器中打开路径
http://localhost:8080/hello/getData,查看运行结果。运行结果。
在 IDEA 的控制台窗口中来查看项目的日志信息和输出结果。
插入数据后的结果。
tomcat 连接池测试0 tomcat 连接池测试1 tomcat 连接池测试2 tomcat 连接池测试3 tomcat 连接池测试4 tomcat 连接池测试5 tomcat 连接池测试6 tomcat 连接池测试7 tomcat 连接池测试8 tomcat 连接池测试9修改数据后的结果。
-----修改后----- POOl 连接池测试0 POOl 连接池测试1 POOl 连接池测试2 POOl 连接池测试3 POOl 连接池测试4 POOl 连接池测试5 POOl 连接池测试6 POOl 连接池测试7 POOl 连接池测试8 POOl 连接池测试9返回给 Web 界面的结果。

项目代码介绍
点击 tomcat-mysql-client 下载项目代码,这是一个名为tomcat-mysql-client的压缩包。
解压后,得到一个名为tomcat-mysql-client的文件夹。目录结构如下所示:
│--pom.xml
│
├─.idea
│
├─src
│ ├─main
│ │ ├─java
│ │ │ └─com
│ │ │ └─oceanbase
│ │ │ └─testtomcat
│ │ │ ├─config
│ │ │ │ └─UserConfig.java
│ │ │ │
│ │ │ ├─controller
│ │ │ │ └─UserController.java
│ │ │ │
│ │ │ └─pojo
│ │ │ └─User.java
│ │ │
│ │ ├─resources
│ │ │ └─application.properties
│ │ │
│ │ └─webapp
│ │ └─WEB-INF
│ │ └─web.xml
│ │
│ │
│ │
│ └─test
│ └─java
│
│
└─target文件说明:
pom.xml:Maven 项目的配置文件,包含了项目的依赖、插件、构建等信息。.idea:IDE(集成开发环境)中使用的目录,用于存储项目相关的配置信息。src:通常用于表示项目中存放源代码的目录。main: 存放主要的源代码和资源文件的目录。java: 存放 Java 源代码的目录。com: 存放 Java 包的根目录。oceanbase: 存放项目的根目录。testtomcat:存放 JFinal 框架的相关代码。config:配置文件目录,包含应用程序的配置类文件。UserConfig.java:用户配置类文件。controller:控制器目录,包含应用程序的控制器类文件。UserController.java:用户控制器类文件。pojo: 存放 JavaBean 或实体类。User.java:存放用户实体类。resources: 存放资源文件的目录,如配置文件、SQL 文件等。application.properties: 存放数据库连接信息的配置文件。webapp:Web 应用程序目录,包含 Web 应用程序的静态资源和配置文件。WEB-INF:Web 应用程序的 WEB-INF 目录,用于存放配置文件和其他受保护的资源文件。web.xml:Web 应用程序的部署描述符文件。test: 存放测试代码和资源文件的目录。target: 存放编译后的 Class 文件、Jar 包等文件的目录。
pom.xml 代码介绍
如果您只是想验证示例,那么请使用默认代码,无需修改。您也可以按照以下讲解,根据自己的需求修改pom.xml文件。
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.oceanbase。通过
<artifactId>指定项目依赖为tomcat-mysql-client。通过
<version>指定项目的版本号为1.0-SNAPSHOT。通过
<packaging>指定项目的打包方式为 WAR 文件(Web 应用程序归档文件)。
代码如下:
<groupId>com.oceanbase</groupId> <artifactId>tomcat-mysql-client</artifactId> <version>1.0-SNAPSHOT</version> <!-- Packaging method (default to jar) --> <packaging>war</packaging>配置 Maven 版本。
通过 <maven.compiler.source> 和 <maven.compiler.target> 指定了编译器的源代码版本和目标代码版本都为 Java 8。
代码如下:
<properties> <maven.compiler.source>8</maven.compiler.source> <maven.compiler.target>8</maven.compiler.target> </properties>配置核心依赖。
指定依赖项所属的组织为 com.jfinal,名称为 jfinal,版本号为 5.0.6,通过该依赖可以使用 JFinal 框架的功能。
代码如下:
<dependency> <groupId>com.jfinal</groupId> <artifactId>jfinal</artifactId> <version>5.0.6</version> </dependency>指定依赖项所属的组织为
com.alibaba,名称为druid,版本号为1.2.8,通过该依赖可以使用 Druid 库,用于管理和优化数据库连接的获取和释放。代码如下:
<dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.2.8</version> </dependency>指定依赖项所属的组织为
org.apache.commons,名称为commons-dbcp2,版本号为2.9.0,通过该依赖可以使用 Apache Commons DBCP2 库,用于管理和优化数据库连接的获取和释放。代码如下:
<dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-dbcp2</artifactId> <version>2.9.0</version> </dependency>指定依赖项所属的组织为
mysql,名称为mysql-connector-java,版本号为5.1.40,通过该依赖可以使用 OceanBase 提供的客户端功能,如连接、查询、事务等。代码如下:
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.40</version> </dependency>
application.properties 文件介绍
application.properties文件配置连接到 OceanBase 数据库的数据库连接信息。包括数据库驱动程序的类名、连接 URL、用户名、密码,以及连接池的相关配置。这些配置项用于在应用程序中获取和管理数据库连接,以便进行数据库操作。
通过
db.app.pool.driverClassName指定数据库驱动程序为com.mysql.jdbc.Driver,用于与 OceanBase 数据库建立连接。通过
db.app.pool.url指定连接数据库的 URL。通过
db.app.pool.username指定连接数据库的用户名。通过
db.app.pool.password指定连接数据库的密码。通过
db.app.pool.initialSize指定连接池的初始大小为3,即初始时创建 3 个数据库连接。通过
db.app.pool.maxTotal指定连接池的最大为10,即连接池中最多可以创建 10 个数据库连接。通过
db.app.pool.maxIdle指定连接池空闲连接数最大为20。通过
db.app.pool.minIdle指定连接池空闲连接数最小为5。通过
db.app.pool.maxWaitMillis指定数据库连接的超时时间为5000ms,即在获取数据库连接时,如果超过 5000ms 仍未获取到连接,则抛出超时异常。通过
db.app.pool.validationQuery指定用于验证数据库连接的 SQL 查询语句为select 1,即在从连接池中获取连接时,会执行这个查询语句来验证连接的有效性。代码如下:
#Apache Commons DBCP2 Connection Pool #Database Connection Pool Driver Class Name db.app.pool.driverClassName=com.mysql.jdbc.Driver #Database URL db.app.pool.url=jdbc:mysql:////host:port/schema_name?characterEncoding=UTF-8 #Database username db.app.pool.username=user_name #Database password db.app.pool.password=****** #Initial size of connection pool db.app.pool.initialSize=3 #Maximum number of connections in the connection pool db.app.pool.maxTotal=10 #Maximum number of idle connections in the connection pool db.app.pool.maxIdle=20 #Minimum number of idle connections in the connection pool db.app.pool.minIdle=5 #Maximum wait time for obtaining connections (in milliseconds) db.app.pool.maxWaitMillis=5000 #Verify the connection's query statement db.app.pool.validationQuery=select 1
Tomcat 内置连接池 DBCP 常用配置项:
具体的属性(参数)配置取决于项目需求和数据库的特点,建议您根据实际情况进行调整和配置。
属性 | 默认值 | 描述 |
username | N/A | 用于指定连接数据库的用户名。 |
password | N/A | 用于指定连接数据库的密码。 |
url | N/A | 用于指定数据库的连接 URL。 |
driverClassName | N/A | 用于指定数据库驱动程序的标准 Java 类名。 |
connectionProperties | N/A | 用于指定建立新连接时发送到 JDBC 驱动程序的连接属性,格式为 |
defaultAutoCommit | driver default | 用于指定连接池创建连接的默认自动提交状态。如果未设置,则不会调用 setAutoCommit 方法。 |
defaultReadOnly | driver default | 用于指定连接池创建连接的默认只读状态。如果未设置,则不会调用 setReadOnly 方法。 |
defaultTransactionIsolation | driver default | 用于指定连接池创建连接的默认事务隔离级别。 |
defaultCatalog | N/A | 用于指定连接池创建的默认连接目录。 |
cacheState | true | 用于指定是否缓存连接的 readOnly 和 autoCommit 设置。如果为 True,则将在第一次读取或写入以及所有后续写入时缓存当前的 readOnly 和 autoCommit 设置。这消除了对 |
defaultQueryTimeout | null | 用于设置连接池中连接创建语句的查询超时时间。如果为非 NULL,则此 Integer 属性的值确定将用于从池管理连接创建语句的查询超时;如果为 NULL,意味着将使用驱动程序默认值。 |
enableAutoCommitOnReturn | true | 用于指定连接返回池时是否检查并配置返回连接的自动提交。 |
rollbackOnReturn | true | 用于指定连接返回池时是否回滚未启用自动提交的、非只读的连接。如果为 True,表示未启用自动提交且连接不是只读的,则连接将在返回池时回滚。 |
initialSize | 0 | 用于设置连接池启动时创建的初始连接数。 |
maxTotal | 8 | 用于设置从连接池中分配的最大活动连接数。 |
maxIdle | 8 | 用于设置连接池中保持空闲的最大连接数,不会释放额外的连接数。若设置为负数表示没有限制。 |
minIdle | 0 | 用于设置连接池中保持空闲的最小连接数,不会创建额外的连接。取值为 0 表示不创建。 |
maxWaitMillis | indefinitely | 用于设置在抛出异常之前,池等待(当没有可用连接时)连接返回的最大毫秒数, 取值为 -1 表示无限期等待。 |
validationQuery | N/A | 用于指定验证连接的 SQL 查询语句。如果指定该值,则必须是至少返回一行 SQL SELECT 语句;如果未指定该值,则连接将通过调用 |
validationQueryTimeout | no timeout | 用于设置连接验证查询失败之前的超时时间,单位为秒。如果设置为正值,则该值通过用于执行验证查询的 setQueryTimeout 方法传递给驱动程序 Statement。 |
testOnCreate | false | 用于指定创建连接后是否验证对象。如果对象无法验证,则触发对象创建的借用尝试将失败。 |
testOnBorrow | true | 用于指定在连接池中借用对象之前是否将对其进行验证的指示。如果对象无法验证,则从连接池中删除该对象,并尝试借用另一个对象。 |
testOnReturn | false | 用于指定对象在返回池之前是否经过验证的指示。 |
testWhileIdle | false | 用于指定对象是否将由空闲对象驱逐器(如果有)验证的指示。如果对象未能通过验证,它将从连接池中删除。 |
timeBetweenEvictionRunsMillis | -1 | 用于设置空闲对象驱逐线程运行间休眠的毫秒数。当取值为非正数时,不会运行空闲对象驱逐线程。 |
numTestsPerEvictionRun | 3 | 用于设置在空闲对象驱逐线程的每次运行期间要检查的对象数。 |
minEvictableIdleTimeMillis | 1000 * 60 * 30 | 用于设置对象在连接池中闲置的最短时间。 |
softMinEvictableIdleTimeMillis | -1 | 用于设置连接在池中处于空闲状态的最短时间,包括 MinIdle 约束。 |
maxConnLifetimeMillis | -1 | 用于设置连接的最大生命周期,单位为毫秒。超过此时间后,连接将无法进行下一次激活、钝化或验证测试。取值为 0 或更小,意味着连接具有无限的生命周期。 |
logExpiredConnections | true | 用于指定是否记录超过最大生命周期而被池关闭的连接。取值为 False 表示禁止启用的过期连接日志记录。 |
connectionInitSqls | null | 用于指定在首次创建物理连接时初始化的 SQL 语句集合。这些语句只在配置的连接工厂创建连接时执行。 |
lifo | true | 用于指定 borrowObject 方法是否返回池中最近使用的连接。取值为 True 表示 borrowObject 返回池中最近使用的 |
poolPreparedStatements | false | 用于指定是否启用准备好的语句池。 |
maxOpenPreparedStatements | unlimited | 用于设置从连接池中分配的最大打开语句数,取值为负数时表示无限制。 |
accessToUnderlyingConnectionAllowed | false | 用于指定是否允许访问底层连接。 |
removeAbandonedOnMaintenance | false | 用于指定连接池维护周期内是否删除废弃的连接。取值为 True 时会在维护周期(驱逐结束时)删除废弃的连接,除非通过将 timeBetweenEvictionRunsMillis 设置为正值来启用维护,否则此属性无效。 |
removeAbandonedOnBorrow | false | 用于指定从连接池中借用连接时是否删除废弃的连接。取值为 True 时每次从池中借用连接时都会删除废弃的连接,并具有以下附加要求:
|
removeAbandonedTimeout | 300 | 用于设置删除废弃连接之前的超时时间,单位为秒。通过配置这个参数,可以指定连接在被视为废弃并可删除之前的最长空闲时间。 |
logAbandoned | false | 用于指定是否记录废弃连接的应用程序代码的堆栈跟踪。由于必须生成堆栈跟踪,因此记录放弃的语句和连接会增加每个连接打开或新语句的开销。 |
abandonedUsageTracking | false | 用于指定是否记录废弃连接的堆栈跟踪。取值为 True,表示每次在池连接上调用方法时,连接池都会记录堆栈跟踪,并保留最近的堆栈跟踪以帮助调试废弃的连接,且设置为 True 会增加大量开销。 |
fastFailValidation | false | 用于指定对抛出致命 SQLException 的连接,验证是否快速失败。取值为 True 时,验证断开连接的请求会立即失败,不会调用驱动程序的 isValid 方法或尝试执行验证查询。被认为是致命错误信号的 SQL_STATE 代码默认如下:
要覆盖此默认断开代码集,请设置 disconnectionSqlCodes 属性。 |
disconnectionSqlCodes | null | 用于指定一组以逗号分隔的 SQL_STATE 代码列表,这些代码被认为是发出致命断开连接错误的信号。当设置 fastFailValidation 参数为 True 时,设置 disconnectionSqlCodes 属性才会生效。 |
jmxName | N/A | 用于指定可操作和监控的数据源对象,将数据源注册为指定名称下的 JMX MBean。该名称必须符合 JMX 对象名称语法(请参见javadoc)。 |
web.xml 代码介绍
web.xml文件用于配置 Web 应用程序的过滤器。
web.xml配置文件内容如下:
文件声明语句。
声明本文件是一个 XML 文件,使用的 XML 版本是
1.0,字符编码方式是UTF-8。代码如下:
<?xml version="1.0" encoding="UTF-8"?>配置 XML 的命名空间和 XML 模型版本。
通过
xmlns:xsi指定 XML 命名空间为http://www.w3.org/2001/XMLSchema-instance。通过
xmlns指定 XML 的命名空间为http://java.sun.com/xml/ns/javaee。通过
xsi:schemaLocation指定 XML 的命名空间为http://java.sun.com/xml/ns/javaee,并指定 XML 的 XSD 文件的位置为http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd。通过
<id>和<version>元素指定 Web 应用程序的 ID 为WebApp_ID,版本号为3.0。
代码如下:
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">配置 JFinal 过滤器。
配置了一个名为
jfinal的过滤器,用于在 Web 应用程序中使用 JFinal 框架。指定过滤器的类为com.jfinal.core.JFinalFilter。通过指定初始化参数configClass,指定 JFinal 框架的配置类的位置为com.oceanbase.testtomcat.config.UserConfig。JFinal 过滤器用于在 Web 应用程序中使用 JFinal 框架,并根据指定的配置类来配置 JFinal 框架的行为。代码如下:
<filter> <filter-name>jfinal</filter-name> <filter-class>com.jfinal.core.JFinalFilter</filter-class> <init-param> <param-name>configClass</param-name> <!-- your jfinal configuration location --> <param-value>com.oceanbase.testtomcat.config.UserConfig</param-value> </init-param> </filter>配置 JFinal 过滤器映射。
将
jfinal过滤器应用到所有的请求路径,即该过滤器将应用于应用程序中的所有请求。代码如下:
<filter-mapping> <filter-name>jfinal</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
UserConfig.java 文件介绍
UserConfig.java文件用于配置应用程序的路由、插件、数据库连接等相关信息。
UserConfig.java文件的代码主要包括以下几个部分:
引用其他类和接口。
声明当前文件包含以下接口和类:
StatFilter类:用于统计数据库访问的性能。JdbcConstants类:用于定义数据库类型的常量。WallFilter类:用于防止 SQL 注入攻击。PropKit类:用于读取配置文件。ActiveRecordPlugin类:用于操作数据库。Db类:用于执行数据库操作。MysqlDialect类:用于指定数据库的方言。DruidPlugin类:用于连接数据库。Engine类:用于配置模板引擎。UserController类:用于处理用户相关的请求。User类:用于传递和存储用户数据。
代码如下:
import com.alibaba.druid.filter.stat.StatFilter; import com.alibaba.druid.util.JdbcConstants; import com.alibaba.druid.wall.WallFilter; import com.jfinal.config.*; import com.jfinal.kit.PropKit; import com.jfinal.plugin.activerecord.ActiveRecordPlugin; import com.jfinal.plugin.activerecord.Db; import com.jfinal.plugin.activerecord.dialect.MysqlDialect; import com.jfinal.plugin.druid.DruidPlugin; import com.jfinal.template.Engine; import com.oceanbase.testjfinal.controller.UserController; import com.oceanbase.testjfinal.pojo.User;定义
UserConfig类。通过重写
JFinalConfig类的各个方法,可以配置常量、路由、插件和数据库连接等信息。定义
configConstant方法。用于配置 JFinal 框架的常量,使用
PropKit读取配置文件中的配置。代码如下:
@Override public void configConstant(Constants constants) { PropKit.use("application.properties"); }定义
configRoute方法。用于配置路由映射,使用
routes.add方法将"/hello"路径映射到UserController类的默认访问页面。代码如下:
@Override public void configRoute(Routes routes) { routes.add("/hello", UserController.class, "/"); }定义
configEngine方法。用于配置模板引擎。
代码如下:
@Override public void configEngine(Engine engine) { }定义
configPlugin方法。用于配置应用程序的插件。通过调用
init方法进行初始化数据库连接和表结构,创建DruidPlugin和ActiveRecordPlugin插件,并将它们添加到plugins中。同时,通过调用activeRecordPlugin的addMapping方法,添加数据库表和实体类的映射关系,将TEST_USER表与User类进行映射。代码如下:
@Override public void configPlugin(Plugins plugins) { init(); DruidPlugin druidPlugin = createDruidPlugin(); plugins.add(druidPlugin); ActiveRecordPlugin activeRecordPlugin = createActiveRecordPlugin(druidPlugin); activeRecordPlugin.addMapping("TOMCAT_TEST", User.class); plugins.add(activeRecordPlugin); }定义
createDruidPlugin方法。用于创建
DruidPlugin插件并配置相关参数,包括连接池大小、SQL 防火墙、连接错误处理等。通过调用
PropKit的get方法,获取配置文件中的数据库连接相关属性值,包括 URL、用户名、密码和驱动类。然后创建DruidPlugin对象,并使用获取到的属性值进行初始化。通过调用
addFilter方法,向DruidPlugin中添加一个StatFilter实例,用于统计数据库访问的性能。创建一个WallFilter实例,通过setDbType方法设置数据库类型为 OceanBase,并将其添加到DruidPlugin中,用于进行 SQL 防火墙过滤。通过调用
setInitialSize方法设置连接池的初始大小;setMaxPoolPreparedStatementPerConnectionSize方法设置每个连接池的最大预处理语句数量;setTimeBetweenConnectErrorMillis方法设置两次连接错误之间的时间间隔;setValidationQuery方法设置连接的验证查询语句。最后,返回创建的DruidPlugin实例。代码如下:
private DruidPlugin createDruidPlugin() { DruidPlugin druidPlugin = new DruidPlugin( PropKit.get("db.app.pool.url"), PropKit.get("db.app.pool.username"), PropKit.get("db.app.pool.password"), PropKit.get("db.app.pool.driverClassName") ); druidPlugin.addFilter(new StatFilter()); WallFilter wallFilter = new WallFilter(); wallFilter.setDbType(JdbcConstants.OCEANBASE); druidPlugin.addFilter(wallFilter); druidPlugin.setInitialSize(PropKit.getInt("db.app.pool.initialSize")); druidPlugin.setMaxPoolPreparedStatementPerConnectionSize(PropKit.getInt("db.app.pool.maxTotal")); druidPlugin.setTimeBetweenConnectErrorMillis(PropKit.getInt("db.app.pool.maxWaitMillis")); druidPlugin.setValidationQuery("select 1"); return druidPlugin; }
定义
init方法。用于初始化数据库连接和创建数据库表。通过调用
initDbConnection方法初始化数据库连接,并返回一个ActiveRecordPlugin实例。其次,通过执行 SQL 语句查询用户表TOMCAT_TEST是否存在。如果表TOMCAT_TEST存在,则执行 SQL 语句DROP TABLE TOMCAT_TEST删除该表。然后执行CREATE TABLE语句创建名为TOMCAT_TEST的数据库表,该表包含ID和USERNAME两个字段。最后关闭ActiveRecordPlugin插件的连接,释放数据库连接。代码如下:
public void init() { ActiveRecordPlugin arp = initDbConnection(); // Check if table exists boolean tableExists = Db.queryInt("SELECT COUNT(*) FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'TEST' AND TABLE_NAME = 'TOMCAT_TEST'") > 0; // Drop table if it exists if (tableExists) { Db.update("DROP TABLE TOMCAT_TEST"); } // Create table String sql = "CREATE TABLE TOMCAT_TEST (ID int, USERNAME varchar(50))"; Db.update(sql); arp.stop(); }定义
initDbConnection方法。用于初始化数据库的连接。首先通过调用
createDruidPlugin方法创建DruidPlugin对象,并将其赋值给变量druidPlugin,该方法负责创建和配置DruidPlugin,用于数据库连接池的管理。其次通过调用createActiveRecordPlugin方法创建ActiveRecordPlugin对象,并将DruidPlugin对象作为参数传递到该方法中,该方法负责创建和配置ActiveRecordPlugin,用于数据库操作的管理。然后调用druidPlugin.start方法启动DruidPlugin初始化数据库连接池。最后调用activeRecordPlugin.start方法启动ActiveRecordPlugin,该方法会根据配置来初始化数据库操作的相关设置。代码如下:
private ActiveRecordPlugin initDbConnection() { DruidPlugin druidPlugin = createDruidPlugin(); ActiveRecordPlugin activeRecordPlugin = createActiveRecordPlugin(druidPlugin); druidPlugin.start(); activeRecordPlugin.start(); return activeRecordPlugin; }定义
ConfigInterceptor和ConfigHandler方法。用于在系统初始化过程中进行全局配置。
代码如下:
@Override public void configInterceptor(Interceptors interceptors) { } @Override public void configHandler(Handlers handlers) { }
UserController.java 文件介绍
UserController.java文件通过getData方法插入数据到数据库并查询数据,并将查询结果以 JSON 格式返回给客户端。通过使用 JFinal 框架提供的Db类执行数据库操作,以及使用自定义的User类进行数据映射,实现对数据库的操作和数据返回的功能。
UserController.java文件的代码主要包括以下几个部分:
引用其他类和接口。
声明当前文件包含以下接口和类:
Controller类:用于处理请求和响应。Db类:用于执行数据库操作。Record类:用于进行数据库操作,查询、插入、更新和删除数据等。ArrayList类:用于创建一个空的列表。User类:用于映射数据库表。List接口:用于操作查询结果集合。
代码如下:
import com.jfinal.core.Controller; import com.jfinal.plugin.activerecord.Db; import com.jfinal.plugin.activerecord.Record; import java.util.ArrayList; import java.util.List;定义
UserController类。用于给 JFinal 框架提供控制器,使用
getData方法对数据库进行插入数据和查询数据操作。插入数据。创建一个包含 10 个
Record对象的列表dataList,每个Record对象都具有不同的ID和USERNAME字段值。然后,使用Db.batchSave方法将dataList列表中的记录批量保存到名为TOMCAT_TEST的数据库表中。代码如下:
for (int i = 0; i < 10; i++) { Record record = new Record().set("ID", i).set("USERNAME", "tomcat 连接池测试" + i); dataList.add(record); } Db.batchSave("TOMCAT_TEST", dataList, dataList.size());查询数据。通过
Db.find方法执行 SQL 查询,将结果存储在resultList列表中。使用增强型的for循环遍历resultList列表中的每个Record对象。通过getStr方法获取Record对象中指定字段的值,并使用System.out.println方法打印输出。代码如下:
List<Record> resultList = Db.find("SELECT * FROM TOMCAT_TEST"); for (Record result : resultList) { System.out.println(result.getStr("USERNAME")); }修改数据。使用循环迭代 10 次,每次迭代都执行一条更新语句。更新语句使用
Db.update方法执行,将名为TOMCAT_TEST的数据库表中的记录根据条件进行更新。代码如下:
for (int i = 0; i < 10; i++) { Db.update("UPDATE TOMCAT_TEST SET USERNAME = 'POOl 连接池测试" + i + "' WHERE ID = " + i); }查询修改后数据。查询名为
TOMCAT_TEST的数据库表,并将结果保存在modifiedList中。打印-----修改后-----的提示信息。遍历modifiedList,打印每个记录的USERNAME字段值。使用renderJson方法将响应消息Data retrieved successfully渲染为 JSON 格式,返回给客户端。代码如下:
List<Record> modifiedList = Db.find("SELECT * FROM TOMCAT_TEST"); System.out.println("-----修改后-----"); for (Record modified : modifiedList) { System.out.println(modified.getStr("USERNAME")); } renderJson("Data retrieved successfully");
User.java 文件介绍
User.java文件用于实现数据库表与 Java 对象的映射。
User.java文件的代码主要包括以下几个部分:
引用
Model类。Model类用于映射数据库表和操作数据。定义
User类。User类通过继承的Model类提供的方法来进行数据库操作。代码如下:
import com.jfinal.plugin.activerecord.Model; public class User extends Model<User> { public static final User dao = new User(); }
完整的代码展示
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<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>
<groupId>com.oceanbase</groupId>
<artifactId>tomcat-mysql-client</artifactId>
<version>1.0-SNAPSHOT</version>
<!-- Packaging method (default to jar) -->
<packaging>war</packaging>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>com.jfinal</groupId>
<artifactId>jfinal</artifactId>
<version>5.0.6</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.8</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-dbcp2</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.40</version>
</dependency>
</dependencies>
</project>application.properties
#Apache Commons DBCP2 Connection Pool
#Database Connection Pool Driver Class Name
db.app.pool.driverClassName=com.mysql.jdbc.Driver
#Database URL
db.app.pool.url=jdbc:mysql:////host:port/schema_name?characterEncoding=UTF-8
#Database username
db.app.pool.username=user_name
#Database password
db.app.pool.password=******
#Initial size of connection pool
db.app.pool.initialSize=3
#Maximum number of connections in the connection pool
db.app.pool.maxTotal=10
#Maximum number of idle connections in the connection pool
db.app.pool.maxIdle=20
#Minimum number of idle connections in the connection pool
db.app.pool.minIdle=5
#Maximum wait time for obtaining connections (in milliseconds)
db.app.pool.maxWaitMillis=5000
#Verify the connection's query statement
db.app.pool.validationQuery=select 1web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<filter>
<filter-name>jfinal</filter-name>
<filter-class>com.jfinal.core.JFinalFilter</filter-class>
<init-param>
<param-name>configClass</param-name>
<!-- your jfinal configuration location -->
<param-value>com.oceanbase.testjfinal.config.UserConfig</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>jfinal</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>UserConfig.java
package com.oceanbase.testtomcat.config;
import com.alibaba.druid.filter.stat.StatFilter;
import com.alibaba.druid.util.JdbcConstants;
import com.alibaba.druid.wall.WallFilter;
import com.jfinal.config.*;
import com.jfinal.kit.PropKit;
import com.jfinal.plugin.activerecord.ActiveRecordPlugin;
import com.jfinal.plugin.activerecord.Db;
import com.jfinal.plugin.activerecord.dialect.MysqlDialect;
import com.jfinal.plugin.druid.DruidPlugin;
import com.jfinal.template.Engine;
import com.oceanbase.testtomcat.controller.UserController;
import com.oceanbase.testtomcat.pojo.User;
public class UserConfig extends JFinalConfig {
@Override
public void configConstant(Constants constants) {
// Read properties configuration
PropKit.use("application.properties");
}
@Override
public void configRoute(Routes routes) {
// Set the default access page for project startup, which does not need to be set in the web.
routes.add("/hello", UserController.class);
}
@Override
public void configEngine(Engine engine) {
}
@Override
public void configPlugin(Plugins plugins) {
init();
DruidPlugin druidPlugin = createDruidPlugin();
plugins.add(druidPlugin);
ActiveRecordPlugin activeRecordPlugin = createActiveRecordPlugin(druidPlugin);
activeRecordPlugin.addMapping("TOMCAT_TEST", User.class);
plugins.add(activeRecordPlugin);
}
private DruidPlugin createDruidPlugin() {
DruidPlugin druidPlugin = new DruidPlugin(
PropKit.get("db.app.pool.url"),
PropKit.get("db.app.pool.username"),
PropKit.get("db.app.pool.password"),
PropKit.get("db.app.pool.driverClassName")
);
druidPlugin.addFilter(new StatFilter());
WallFilter wallFilter = new WallFilter();
wallFilter.setDbType(JdbcConstants.OCEANBASE);
druidPlugin.addFilter(wallFilter);
druidPlugin.setInitialSize(PropKit.getInt("db.app.pool.initialSize"));
druidPlugin.setMaxPoolPreparedStatementPerConnectionSize(PropKit.getInt("db.app.pool.maxTotal"));
druidPlugin.setTimeBetweenConnectErrorMillis(PropKit.getInt("db.app.pool.maxWaitMillis"));
druidPlugin.setValidationQuery("select 1 from dual");
return druidPlugin;
}
private ActiveRecordPlugin createActiveRecordPlugin(DruidPlugin druidPlugin) {
ActiveRecordPlugin activeRecordPlugin = new ActiveRecordPlugin(druidPlugin);
activeRecordPlugin.setDialect(new MysqlDialect());
return activeRecordPlugin;
}
public void init() {
ActiveRecordPlugin arp = initDbConnection();
// Check if table exists
boolean tableExists = Db.queryInt("SELECT COUNT(*) FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'TEST' AND TABLE_NAME = 'TOMCAT_TEST'") > 0;
// Drop table if it exists
if (tableExists) {
Db.update("DROP TABLE TOMCAT_TEST");
}
// Create table
String sql = "CREATE TABLE TOMCAT_TEST (ID int, USERNAME varchar(50))";
Db.update(sql);
arp.stop();
}
private ActiveRecordPlugin initDbConnection() {
DruidPlugin druidPlugin = createDruidPlugin();
ActiveRecordPlugin activeRecordPlugin = createActiveRecordPlugin(druidPlugin);
druidPlugin.start();
activeRecordPlugin.start();
return activeRecordPlugin;
}
@Override
public void configInterceptor(Interceptors interceptors) {
}
@Override
public void configHandler(Handlers handlers) {
}
}UserController.java
package com.oceanbase.testtomcat.controller;
import com.jfinal.core.Controller;
import com.jfinal.plugin.activerecord.Db;
import com.jfinal.plugin.activerecord.Record;
import java.util.ArrayList;
import java.util.List;
public class UserController extends Controller {
public void getData() {
try {
List<Record> dataList = new ArrayList<>();
// 插入数据
for (int i = 0; i < 10; i++) {
Record record = new Record().set("ID", i).set("USERNAME", "tomcat 连接池测试" + i);
dataList.add(record);
}
Db.batchSave("TOMCAT_TEST", dataList, dataList.size());
// 查询数据
List<Record> resultList = Db.find("SELECT * FROM TOMCAT_TEST");
for (Record result : resultList) {
System.out.println(result.getStr("USERNAME"));
}
// 修改数据
for (int i = 0; i < 10; i++) {
Db.update("UPDATE TOMCAT_TEST SET USERNAME = 'POOl 连接池测试" + i + "' WHERE ID = " + i);
}
// 查询修改后的数据
List<Record> modifiedList = Db.find("SELECT * FROM TOMCAT_TEST");
System.out.println("-----修改后-----");
for (Record modified : modifiedList) {
System.out.println(modified.getStr("USERNAME"));
}
renderJson("Data retrieved successfully");
} catch (Exception e) {
e.printStackTrace();
renderJson("Error occurred");
}
}
}User.java
package com.oceanbase.testtomcat.pojo;
import com.jfinal.plugin.activerecord.Model;
public class User extends Model<User> {
public static final User dao = new User();
}相关文档
更多 OceanBase Connector/J 的信息,请参见 OceanBase JDBC 驱动程序。
