当前位置: 首页 > news >正文

云南省建设培训网站中铁建设集团登陆

云南省建设培训网站,中铁建设集团登陆,免费的看电影电视剧的app,个人的网站怎么备案简介 Liquibase是一个用于用于跟踪、管理和应用数据库变化的开源工具#xff0c;通过日志文件(changelog)的形式记录数据库的变更(changeset)#xff0c;然后执行日志文件中的修改#xff0c;将数据库更新或回滚(rollback)到一致的状态。它的目标是提供一种数据库类型无关的…简介 Liquibase是一个用于用于跟踪、管理和应用数据库变化的开源工具通过日志文件(changelog)的形式记录数据库的变更(changeset)然后执行日志文件中的修改将数据库更新或回滚(rollback)到一致的状态。它的目标是提供一种数据库类型无关的解决方案通过执行schema类型的文件来达到迁移。本文主要介绍SpringBoot与Liquibase的集成。 优点 支持几乎所有主流的数据库目前支持包括 Oracle/Sql Server/DB2/MySql/Sybase/PostgreSQL等 各种数据库这样在数据库的部署和升级环节可帮助应用系统支持多数据库支持版本控制这样就能支持多开发者的协作维护日志文件支持多种格式如XML, YAML, JSON, SQL等提供变化应用的回滚功能可按时间、数量或标签tag回滚已应用的变化。通过这种方式开发人员可轻易的还原数据库在任何时间点的状态支持多种运行方式如命令行、Spring集成、Maven插件、Gradle插件等。 简单示例 这里主要介绍基于SpringBoot集成liquibase来管理数据库的变更。 POM依赖 Maven 包的依赖主要包含mysql驱动, JDBC(这里spring-boot-starter-data-jpa包含了jdbc包当然直接引入jdbc包也行)以及liquibase包。 dependencygroupIdmysql/groupIdartifactIdmysql-connector-java/artifactIdversion8.0.28/version /dependency dependencygroupIdcom.github.wenhao/groupIdartifactIdjpa-spec/artifactIdversion3.1.0/version /dependency dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-jpa/artifactId /dependencydependencygroupIdorg.liquibase/groupIdartifactIdliquibase-core/artifactIdversion4.9.1/version /dependencyyml配置 SpringBoot AutoConfig默认已经包含了对liquibase的配置在spring.liquibase配置下。 基础的配置可以直接使用如下主要是指定change-log的位置默认的位置是classpath:/db/changelog/db.changelog-master.yaml spring:datasource:url: jdbc:mysql://localhost:3306/test_db_liquibase?useSSLfalseautoReconnecttruecharacterEncodingutf8driver-class-name: com.mysql.cj.jdbc.Driverusername: rootpassword: bfXa4Pt2lUUScy8jakXfliquibase:enabled: true# 如下配置是被spring.datasource赋值的所以可以不配置 # url: jdbc:mysql://localhost:3306/test_db_liquibase?useSSLfalseautoReconnecttruecharacterEncodingutf8 # user: root # password: bfXa4Pt2lUUScy8jakXfchange-log: classpath:/db/changelog/db.changelog-master.yaml新增changelog XML方式固然OK不过依然推荐使用yml格式。 databaseChangeLog:- changeSet:id: 20220412-01author: pdaichanges:- createTable:tableName: personcolumns:- column:name: idtype: intautoIncrement: trueconstraints:primaryKey: truenullable: false- column:name: firstnametype: varchar(50)- column:name: lastnametype: varchar(50)constraints:nullable: false- column:name: statetype: char(2)- changeSet:id: 20220412-02author: pdaichanges:- addColumn:tableName: personcolumns:- column:name: usernametype: varchar(8)- changeSet:id: 20220412-03author: pdaichanges:- addLookupTable:existingTableName: personexistingColumnName: statenewTableName: statenewColumnName: idnewColumnDataType: char(2)测试 启动springBootApplication, 我们可以看到如下的几个changeSet被依次执行 2022-04-12 20:41:20.591 INFO 8476 --- [ main] liquibase.lockservice : Successfully acquired change log lock 2022-04-12 20:41:20.737 INFO 8476 --- [ main] liquibase.changelog : Creating database history table with name: test_db_liquibase.DATABASECHANGELOG 2022-04-12 20:41:20.783 INFO 8476 --- [ main] liquibase.changelog : Reading from test_db_liquibase.DATABASECHANGELOG Running Changeset: classpath:/db/changelog/db.changelog-master.yaml::20220412-01::pdai 2022-04-12 20:41:20.914 INFO 8476 --- [ main] liquibase.changelog : Table person created 2022-04-12 20:41:20.914 INFO 8476 --- [ main] liquibase.changelog : ChangeSet classpath:/db/changelog/db.changelog-master.yaml::20220412-01::pdai ran successfully in 53ms Running Changeset: classpath:/db/changelog/db.changelog-master.yaml::20220412-02::pdai 2022-04-12 20:41:20.952 INFO 8476 --- [ main] liquibase.changelog : Columns username(varchar(8)) added to person 2022-04-12 20:41:20.952 INFO 8476 --- [ main] liquibase.changelog : ChangeSet classpath:/db/changelog/db.changelog-master.yaml::20220412-02::pdai ran successfully in 31ms Running Changeset: classpath:/db/changelog/db.changelog-master.yaml::20220412-03::pdai 2022-04-12 20:41:21.351 INFO 8476 --- [ main] liquibase.changelog : Lookup table added for person.state 2022-04-12 20:41:21.351 INFO 8476 --- [ main] liquibase.changelog : ChangeSet classpath:/db/changelog/db.changelog-master.yaml::20220412-03::pdai ran successfully in 389ms 2022-04-12 20:41:21.382 INFO 8476 --- [ main] liquibase.lockservice : Successfully released change log lock查看数据库你会发现数据已经变更 那我们如果重新启动这个SpringBootApplication会怎么呢 很显然因为databasechangelog表中已经有相关执行记录了所以将不再执行变更 2022-04-12 20:49:01.566 INFO 9144 --- [ main] liquibase.lockservice : Successfully acquired change log lock 2022-04-12 20:49:01.761 INFO 9144 --- [ main] liquibase.changelog : Reading from test_db_liquibase.DATABASECHANGELOG 2022-04-12 20:49:01.812 INFO 9144 --- [ main] liquibase.lockservice : Successfully released change log lock## 进一步理解### 比较好的changelog的实践 简单而言yml格式 sql-file方式执行sqlFile格式的changeSet如下 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/857a01879d394aa2a4e920c25cc069e2.png) 执行的日志如下log 2022-04-12 21:00:28.198 INFO 17540 --- [ main] liquibase.lockservice : Successfully acquired change log lock 2022-04-12 21:00:28.398 INFO 17540 --- [ main] liquibase.changelog : Reading from test_db_liquibase.DATABASECHANGELOG Running Changeset: classpath:/db/changelog/db.changelog-master.yaml::20220412-04::pdai 2022-04-12 21:00:28.516 INFO 17540 --- [ main] liquibase.changelog : SQL in file classpath:/db/changelog/db.changelog-20220412-04.sql executed 2022-04-12 21:00:28.516 INFO 17540 --- [ main] liquibase.changelog : ChangeSet classpath:/db/changelog/db.changelog-master.yaml::20220412-04::pdai ran successfully in 83ms 2022-04-12 21:00:28.532 INFO 17540 --- [ main] liquibase.lockservice : Successfully released change log lock执行后查看变更记录 数据表user表已经创建并插入一条数据
http://www.hkea.cn/news/14449993/

相关文章:

  • 网站服务器租用的建网站没有实体公司能建站吗
  • 在哪个网站上做预收款报告口碑好的网站开发
  • 连云港公司企业网站建设做网站必须要服务器吗
  • 母婴电子商务网站建设网站宽度 像素
  • 网站建设建站经验福州网站建设新闻
  • 网站建设的会计科目改则网站建设
  • 做电子商务的网站成都网站建设推广可以
  • 南通城乡住房建设厅网站首页怎么制作网址
  • 在设计赚钱的网站有哪些局 网站建设方案
  • 目前市面上做网站的程序2023免费推广入口
  • 古镇网站建设哪家好google地图嵌入网站
  • 汕头自助建站系统网站营销推广如何做
  • 大学网站建设策划书工商营业执照官网
  • 网站建设域名服务器网络公司个人工作总结
  • 杭州建电商网站多少钱好看的登录页面自适应模板
  • 优质的广州微网站建设文明网站的建设与管理的思考
  • 厦门手机网站新泰房产信息与住宅网
  • 深圳建设网站费用网站建设和网络推广方案
  • 建站软件移动版网页小游戏开发
  • 鲁 网站 备案国内手机app开发公司
  • 营销型网站哪家好怀化找工作网站
  • 高创园网站建设方案网络营销哪家比较专业
  • 个人网站怎么写江苏金地建设工程有限公司网站
  • 怎么把自己的网站放到百度搜索上深圳模板建站代理
  • 上海小企业网站建设平台做网站用微软雅黑侵权吗
  • 网站建设技术培训学校深圳宝安区属于富人区吗
  • 已有网站备案网站数据分析平台
  • 高中做信息技术题网站优秀品牌设计案例分析
  • 泗水县城乡建设局网站wordpress 文章 图片 插件
  • 特效网站淘客网站建设要求