标签:name column 数据库 Liquibase value liquibase 迁移 true 工具
数据库迁移工具(二)
Liquibase定义数据库迁移过程
Liquibase可以使用多种格式书写迁移脚本(XML,YAML,JSON,SQL)
Liquibase依赖
<dependency>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-core</artifactId>
</dependency>
这里没有指定版本,查看后得知自动倒入了3.8.2版本
添加spring配置信息
spring:
liquibase:
enabled: true
change-log: classpath:db/changelog/*.yaml
这里如果不进行配置,默认会从 classpath:/db/changelog/db.changelog-master.xml 处读取文件信息
接下来添加liquibase文件,文件目录即为配置文件中的目录
databaseChangeLog:
- changeSet:
id: 1
author: rootdeng
changes:
- createTable:
tableName: liquibase_table
columns:
- column:
name: id
type: int
autoIncrement: true
constraints:
unique: true
nullable: false
primarkKey: true
- column:
name: field_name
type: varchar(25)
constraints:
nullable: false
- column:
name: field_value
type: varchar(85)
constraints:
nullable: false
- insert:
tableName: liquibase_table
columns:
- column:
name: field_name
value: 测试
- column:
name: field_value
value: 成功
上面的文件展示了数据表从创建(createTable)到插入数据(insert)的写法
Flyway有多个脚本,每个脚本对应一个变更集。Liquibase变更集都集中在一个配置文件中,通过changeset中的id进行区分,应用程序启动时,Liquibase会使用databaseChangeLog表中的内容进行对比,执行未运行的变更集
下图是执行结果
标签:name,column,数据库,Liquibase,value,liquibase,迁移,true,工具 来源: https://blog.csdn.net/zhangdy12307/article/details/121462889
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。