讲在前头:本篇阐述springboot集成activiti7数据库创建方式
环境:
- IDE:IDEA 2020.3
- SpringBoot:2.4.2
- Activiti:7.0.0.Beta1
你应该知道的:springboot是从spring的基础上演变而来的,相对于spring来说的话,springboot的配置会更加简化一点,不仅表现在多了很多注解方式导入bean,更是表现在依赖引入方面,springboot对原有的依赖包进行了又一层的封装
你还应该知道的:创建一个项目我们应该做的事情有哪些?
- 导入坐标(依赖)
- 创建包
- 修改配置文件
- 写项目代码
ok,那么就从导入坐标开始,我们需要导入的依赖坐标如下:
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.2</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.sun</groupId>
<artifactId>improve</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>improve</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.activiti</groupId>
<artifactId>activiti-spring-boot-starter</artifactId>
<version>7.0.0.Beta1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
导入坐标之后需要做的就是建包:(这步随意,看个人喜好),敝人包路径如下:
接下来就是配置,配置文件如下(文件名为activiti.cfg.xml)
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
<property name="databaseType" value="mysql"></property>
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/activiti"></property>
<property name="jdbcDriver" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUsername" value="root"></property>
<property name="jdbcPassword" value="123456"></property>
</bean>
</beans>
这边我是把ProcessEngineConfiguration(引擎的配置)和MySQL(这边使用的是mysql数据库,也可以切换到其他数据库,这个随意)的配置写到了一起,其实应该分开进行配置,各司其职,如下:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="datasource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/activiti"></property>
<property name="username" value="root"></property>
<property name="password" value="123456"></property>
</bean>
<bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
<property name="datasource" ref="dataSource"></property>
</bean>
</beans>
ok,接下来来说一下创建数据库的代码实现(这里只将一下最简单的实现方式,复杂方式本质上和简单方式思想一样)
public class CreateDB {
public static void main(String[] args) {
DbSchemaCreate.main(args);
}
}
ok,结束。
.
.
.
.
你肯定也想不到会这么简单吧,但表面上就是这么简单,但是还是很有内涵的,那么就来剖析一下内涵吧. . .
点进DbSchemaCreate的main方法
public static void main(String[] args) {
ProcessEngineConfiguration.createProcessEngineConfigurationFromResourceDefault()
.setDatabaseSchemaUpdate("create").buildProcessEngine();
}
点进去是这幅鬼样子,其实就是执行了ProcessEngineConfiguration类的三个方法:
public static ProcessEngineConfiguration createProcessEngineConfigurationFromResourceDefault() {
return createProcessEngineConfigurationFromResource("activiti.cfg.xml", "processEngineConfiguration");
}
public ProcessEngineConfiguration setDatabaseSchemaUpdate(String databaseSchemaUpdate) {
this.databaseSchemaUpdate = databaseSchemaUpdate;
return this;
}
public abstract ProcessEngine buildProcessEngine();
解释:前两个方法就是在加载配置,首先第一个是根据xml配置创建对象,第二个方法是对创建出来的对象属性进行修改(构造器方法),第三个创建根据引擎配置创建引擎对象–根本
划重点:不知道你们有没有注意到,createProcessEngineConfigurationFromResourceDefault方法的内部实现,是从resource目录下获取activiti.cfg.xml文件的配置进行创建bean操作,这也就是说如果你的配置文件名不是activiti.cfg.xml,那么不好意思bean无法被创建,会报错的,如果你不想使用这个名称的配置文件,那么你就不能使用这种默认的方式,可以根据这个默认方式的思想通过他们的重载方法进行创建操作,这里就不做详细叙述。
接下来需要做的就是执行方法,执行结果如下:
一共是25张表,每张表都有他独特的任务,互帮互助,相互合作,实现大业. . .
知道的越多,不知道的越多,建议不要使用idea 2019以上版本进行初步学习,忒麻烦!!!