H2Database自定义函数

t# H2Database自定义函数

前言

h2数据库其实更多的用在开发中,因为可以内嵌,所以一般作为内存数据库,随用随创,随时删除。其中spring data jpa就使用到了这个数据库,再加上数据库版本控制工具flyway或者liquibase,就可以方便的在各个数据库中进行迁移和升级,我现在一般的工作的方式是开发在h2数据库中,生产环境是mysql的。但是h2在迁移的过程中sql其实很多是通用的。但是不可避免的会出现某些数据库有的函数,h2中没有的情况。所以今天就介绍一下在内嵌的h2数据库中使用自定义函数

条件

首先我这边使用的是spring data jpa和liquibase,项目只需要加个h2database的依赖就可以使用h2点内嵌数据库.简单配置如下

  • gradle中依赖配置
dependencies {
    compile('org.springframework.boot:spring-boot-starter-data-jpa')
    runtime('org.liquibase:liquibase-core')
    runtime('com.h2database:h2')
    runtime('mysql:mysql-connector-java')
    testCompile("junit:junit")
}
  • Spring boot 配置
liquibase
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Flowable 中,你可以使用条件表达式(condition expression)来定义流程或任务的条件。条件表达式通常是一个布尔类型的表达式,它用于决定流程或任务是否应该继续执行。在条件表达式中,你可以使用各种运算符和函数来执行各种操作。如果你想要使用自定义函数,可以按照以下步骤进行操作: 1. 创建一个实现了 Condition 函数接口的类。例如,下面是一个示例类,它实现了 Condition 函数接口,并定义了一个名为 `isEven` 的自定义函数: ```java public class CustomFunctions implements Condition { public boolean isEven(int number) { return number % 2 == 0; } @Override public boolean evaluate(DelegateExecution execution) { // 这里可以实现你的条件逻辑 return true; } } ``` 2. 在你的流程定义文件中,使用 `flowable:classDelegateExpression` 属性来指定自定义函数的类。例如,下面是一个示例流程定义文件,它使用了自定义函数 `isEven`: ```xml <process id="myProcess" name="My process"> <startEvent id="start" /> <sequenceFlow id="flow1" sourceRef="start" targetRef="task1" /> <userTask id="task1" name="My task"> <extensionElements> <flowable:conditionExpression xsi:type="flowable:tFormalExpression"> <![CDATA[${customFunctions.isEven(2)}]]> </flowable:conditionExpression> <flowable:classDelegateExpression xsi:type="flowable:tFormalExpression"> <![CDATA[com.example.CustomFunctions]]> </flowable:classDelegateExpression> </extensionElements> </userTask> <sequenceFlow id="flow2" sourceRef="task1" targetRef="end" /> <endEvent id="end" /> </process> ``` 在上面的示例中,我们在 `userTask` 元素中使用了 `flowable:conditionExpression` 属性来定义条件表达式,其中使用了自定义函数 `isEven(2)`。我们还使用了 `flowable:classDelegateExpression` 属性来指定自定义函数的类。 3. 在你的 Java 代码中,创建一个 ProcessEngineConfigurationImpl 对象,并将自定义函数的类注册到它的 `getBeans()` 方法中。例如,下面是一个示例代码,它创建了一个 ProcessEngineConfigurationImpl 对象,并将自定义函数的类注册到它的 `getBeans()` 方法中: ```java ProcessEngineConfigurationImpl config = new StandaloneProcessEngineConfiguration() .setJdbcUrl("jdbc:h2:mem:flowable;DB_CLOSE_DELAY=-1") .setJdbcUsername("sa") .setJdbcPassword("") .setJdbcDriver("org.h2.Driver") .setDatabaseSchemaUpdate(ProcessEngineConfiguration.DB_SCHEMA_UPDATE_TRUE); config.getBeans().put("customFunctions", new CustomFunctions()); ProcessEngine engine = config.buildProcessEngine(); ``` 在上面的示例中,我们首先创建了一个 ProcessEngineConfigurationImpl 对象,然后将自定义函数的类注册到它的 `getBeans()` 方法中。这样,当 Flowable 引擎启动时,它就会自动识别并加载我们的自定义函数。 通过以上步骤,你就可以在 Flowable 中使用自定义函数来编写条件表达式了。注意,如果你在使用自定义函数时遇到问题,请确保你的自定义函数类已经正确导入,并且你已经正确地配置了 Flowable 引擎。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值