Flyway数据库迁移到多个模式

use*_*206 6 java database migration maven flyway

我为我的多租户应用程序设置了一个迁移脚本.问题是.它只生成我在参数上指定的第一个租户/架构的脚本.这是我的sql脚本

drop table if exists ADMIN_ACCOUNT cascade;

drop table if exists PERSON_NAME cascade;

drop table if exists USER_ACCOUNT cascade;

create table ADMIN_ACCOUNT (
    id int8 not null,
    created_date timestamp,
    PASSWORD varchar(255),
    USERNAME varchar(255),
    membershipType varchar(255),
    NAME_ID int8,
    primary key (id)
);

create table PERSON_NAME (
    id int8 not null,
    created_date timestamp,
    FIRST_NAME varchar(255),
    LAST_NAME varchar(255),
    MIDDLE_NAME varchar(255),
    account_id int8,
    primary key (id)
);

create table USER_ACCOUNT (
    id int8 not null,
    created_date timestamp,
    PASSWORD varchar(255),
    USERNAME varchar(255),
    ROLE varchar(255),
    TENANT_CODE varchar(255),
    NAME_ID int8,
    primary key (id)
);

alter table ADMIN_ACCOUNT
add constraint FK_fil1krx8k0osj713tg44ia0vu
foreign key (NAME_ID)
references PERSON_NAME;

alter table PERSON_NAME
add constraint FK_hc1g7pa0rseytw9o1pcuo0mpw
foreign key (account_id)
references USER_ACCOUNT;

alter table USER_ACCOUNT
add constraint FK_ib2pk4at20vxm3onaoro6ry2r
foreign key (NAME_ID)
references PERSON_NAME;
Run Code Online (Sandbox Code Playgroud)

这是我进入飞路的命令 mvn compile flyway:migrate -Dflyway.schemas=tenant3,tenant4,tenant5 -Dflyway.baselineOnMigrate=true

它只生成第一个租户的表,即tenant3.

这是一个错误吗?还是错过了什么?

Axe*_*ine 4

要创建多个相同的模式,您必须为每个模式调用一次 Flyway,并将 Flyway.schemas 属性设置为正确的值。然后,Flyway 会将正确的架构设置为默认架构,让您无需更改即可运行迁移脚本(只要不为对象名称添加前缀)。