java每次发布新版本 但是数据库字段改了 线上怎么同步结构比较好?
java每次发布新版本 但是数据库字段改了 线上怎么同步字段结构比较好?有没有什么办法可以自动对比数据库的结构,并进行新增,我知道有数据库工具可以,但是我是想把这个操作,做到java里面,他jar包一启动自动识别是否有新增字段并进行处理,暂时不用考虑新增或减少字段会存在数据冲突的问题 JPAspring:
jpa:
hibernate:
# 创建或者更新时间表结构
ddl-auto: update liuquibase和Flyway你可以看一下,每次更改数据结构都在java中做一个版本记录 本帖最后由 liyangit 于 2022-8-9 14:23 编辑
数据库有对应属性方法api,比如获取全部数据库,数据库所有表,表所有字段。有更方便简洁的方法为什么要用代码去实现,如果你是在 传统公司或者 硬需求就是要这个功能 那没毛病,如果是在外包 直接会被骂的,这种需求客户不可能会提出来,懂技术的更不会去提这个需求了, 你的这些需求完全可以每发布一个版本,就复制一份sql源文件,就搞定了, 还有开源的 sql工具,可以直接获取数据库改动信息 之前我们线上系统是内网,将开发环境的表结构和部署包全部拷到内网,然后使用 Python 脚本连接线上数据库,然后和开发环境的表结构进行对比,生成需要执行的ddl语句。也有点挺麻烦 spring data jpa里面有对应的自适应字段配置 把 sql update 的 语句 alter table add column xxx 以字符串形式维护到数据库里
之后更新到时候 java 拉数据执行 sql 在用liquebase flyway可以去看一下 flyway,我们公司用的就是
页:
[1]