我有一个新的mysql实例,希望能够创建大量数据库并用liquibase填充它。虽然我有脚本(变更集)可以在手动创建的数据库上很好地工作,但我也希望能够使用liquibase创建数据库。当我尝试在URL中不指定数据库的情况下连接时,我得到了错误:
liquibase --driver=com.mysql.jdbc.Driver --url=jdbc:mysql://localhost:3306/ --username=root --password=admin --changeLogFile=create_dbs.sql tag empty
Unexpected error running Liquibase: Incorrect database name '' [Failed SQL: CREATE TABLE ``.DATABASECHANGELOGLOCK (ID INT NOT NULL, LOCKED BIT(1) NOT NULL, LOCKGRANTED datetime NULL, LOCKEDBY VARCHAR(255) NULL, CONSTRAINT PK_DATABASECHANGELOGLOCK PRIMARY KEY (ID))]
我不需要liquibase跟踪这些更改(数据库创建),似乎我想使用LB作为快速引导工具。
首先需要在URL中添加数据库名称,如jdbc:mysql://localhost:3306/database_name
。
您也可以使用这个URL 创建一个新的数据库
jdbc:mysql://localhost:3306/database_name?createDatabaseIfNotExist=true
createDatabaseIfNotExist这个关键字在您的系统中创建一个新的数据库。如果数据库不存在。如果存在,则跳过执行。
如何使用Liquibase 创建数据库
您需要在URL中指定数据库。
编辑
Liquibase实际上并没有完成创建具有权限等的空数据库的第一步。这必须使用平台的本地工具来完成。一旦一个空数据库就位,liquibase将通过创建正确的表等来填充数据库模式。