`
liangjing23
  • 浏览: 1091 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

dbmaintian

阅读更多

dbmaintain的应用

 

参考文件:http://www.dbmaintain.org/overview.html。

 

项目中想用dbmaintain来自动管理数据库脚本,但网上相关资料太少,除了官方http://www.dbmaintain.org/overview.html。 所以本人根据官方网站,把自己的尝试经验给分享一下,请多多指正。好了,废话少说,创建一个例子,然后再说明细节以及注意的地方。

一创建例子(在这里我选用java代码来做,除此之外还有ant, 命令行)
1, 巧妇难为无米之炊,先下载需要用到的jar包,https://sourceforge.net/projects/dbmaintain/files/ 目前最新版本dbmaintain-1.0.1-src.zip 解压缩之后就可看到一个lib目录,里面的两个jar包等下就是我们要用的。

2, 创建一个web project(当然java project也一样),导入上面提到的两个jar包commons-logging-1.1.1.jar and dbmaintain-1.0.1.jar,另外,还需要额外导入一个jdbc的jar包,别忘了,我们是要操作数据库。在这个我用的是mysql-connector-java-5.1.7-bin.jar.

3, 配置 dbmaintain.properties,这个比较多一点,见附件,里面做了说明。(我的意思很简单,先运行起来再说)。当然,你可以有两个地方找到这个文件,一种是到官网 http://www.dbmaintain.org/configuration.html 复制下来,(我是用这个,因为是简洁版)。另一个是在我们上面下的压缩包里(注意只有含源文件包里才有),解压缩后的目录dbmaintain-1.0.1-src\src\resources\dbmaintain-default.properties。

4,组织sql scripts,这是重点,四种脚本类型(Incremental Repeatable Postprocessing Patches),下面一一道来。

先看组织方式,混个脸熟
 
scripts/incremental/01_v1.0/01_products_and_orders.sql
                                                    02_users.sql
                                                    03_#PATCH_add_status.sql
                               02_v1.1/01_add_barcode_column.sql
                                             02_drop_itemcode_column.sql
          repeatable/proc_purge_old_orders.sql
                              proc_disactivate_inactive_users.sql
   postprocessing/01_compile_all.sql
                                 02_grant_select_to_read_user.sql
                      
  1) Incremental,顾名思义,增量式的,有顺序的。说明:scripts是所有脚本的总目录,随便你怎么命名,下面有三个目录,分别对应三种脚本类型,Patches除外。incremental放增量式脚本的目录,目录名字可以任取。下面可以再定义文件夹,此时文件夹就有序号了(index number),这里的两个文件夹是体现两个版本的。
                   
  注意:这种脚本时会按顺序执行(从小到大),且每个脚本只执行一次。
 
  2) Repeatable,顾名思义,可重复执行的,为什么要弄个可重复执行呢?因为我们有经常要修改的脚本,如function ,procedure,views,每次修改完之后,就会执行一遍。
     
  注意:这种脚本不可以有编号, 不可以放到有编号的目录下,否则会报错。
 
  3) Postprocessing, 我给的理解是后置执行,也就是等所有的脚本都执行完了之后,才执行。但它也不是每次都执行,什么时候会被执行呢?当脚本有变动,包括Postprocessing目录下的脚本,则所有的postprocessing脚本都会执行一遍。比如我们修改了repeatable/proc_purge_old_orders.sql,
     
  注意:目录名必须是postprocessing, 如果不是则被认为是Incremental脚本。可以有index number(序号),如果有序号则会按顺序执行。
 
  4) Patches,补丁。什么情况才算是补丁呢?用官方的话说就是:当你要增加一个脚本,而它的序号低于已经执行过的脚本的序号时,这个脚本就必须是补丁形式,否则会报错。比如上面的 03_#PATCH_add_status.sql 是新加进去的,(补丁的组织形式就是在序号后面加上#PATCH就行,如例子),我们的脚本已经执行到了文件夹02_v1.1里面了,很明显,这个序号高于01_v1.0下的所有序号,满足打补丁的情况。
 
5,创建数据库,dbmaintain,dbmaintain2,创建两个是为了说明同时管理多个数据库的情况。参考附件,多数据库组织方式1.jpg (对脚本文件区分);  多数据库组织方式2.jpg(用文件夹区分,建议使用), 配置在配置文件里有说明,只要把对应的参数改过来就行。

6,建一个类DBMaintain.java,看附件,里面有对主要命令的说明。完毕

总结,搭建好环境之后,就是组织脚本格式,和配置dbmaintain.properties就可行了。

 

  • 大小: 7.7 KB
  • 大小: 12.6 KB
2
0
分享到:
评论

相关推荐

    基于opencv实现象棋识别及棋谱定位python源码+数据集-人工智能课程设计

    基于opencv实现象棋识别及棋谱定位python源码+数据集-人工智能课程设计,含有代码注释,满分课程设计资源,新手也可看懂,期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。该项目可以作为课程设计期末大作业使用,该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 基于opencv实现象棋识别及棋谱定位python源码+数据集-人工智能课程设计,含有代码注释,满分课程设计资源,新手也可看懂,期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。该项目可以作为课程设计期末大作业使用,该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 基于opencv实现象棋识别及棋谱定位python源码+数据集-人工智能课程设计,含有代码注释,满分课程设计资源,新手也可看懂,期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。该项目可以作为课程设计期末大作业使用,该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。基于opencv实现象棋识别及棋谱定位python源码+数据集

    基于Python实现的Cowrie蜜罐设计源码

    该项目为基于Python实现的Cowrie蜜罐设计源码,共计380个文件,涵盖166个Python源代码文件,以及包括RST、SQL、YAML、Markdown等多种类型的配置和文档文件。Cowrie蜜罐是一款用于记录暴力攻击和攻击者执行的SSH及Telnet交互的中等交互式蜜罐。

    QT 摄像头获取每一帧图像数据以及opencv获取清晰度

    QT 摄像头获取每一帧图像数据以及opencv获取清晰度

    基于asp.net的(CS)地震预测系统设计与实现.docx

    基于asp.net的(CS)地震预测系统设计与实现.docx

    基于Springboot和Mysql的医院药品管理系统代码(程序,中文注释)

    医院药品管理系统-医院药品管理系统-医院药品管理系统-医院药品管理系统-医院药品管理系统-医院药品管理系统-医院药品管理系统-医院药品管理系统-医院药品管理系统-医院药品管理系统-医院药品管理系统-医院药品管理系统 1、资源说明:医院药品管理系统源码,本资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 2、适用人群:计算机相关专业(如计算计、信息安全、大数据、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工等学习者,作为参考资料,进行参考学习使用。 3、资源用途:本资源具有较高的学习借鉴价值,可以作为“参考资料”,注意不是“定制需求”,代码只能作为学习参考,不能完全复制照搬。需要有一定的基础,能够看懂代码,能够自行调试代码,能够自行添加功能修改代码。 4. 最新计算机软件毕业设计选题大全(文章底部有博主联系方式): https://blog.csdn.net/2301_79206800/article/details/135931154 技术栈、环境、工具、软件: ① 系统环境:Windows ② 开发语言:Java ③ 框架:SpringBo

    mqtt单点到点聊天工具

    mqtt单点到点聊天工具

    【图像融合】基于matlab GUI拉普拉斯金字塔+小波变换图像融合【含Matlab源码 857期】.zip

    CSDN海神之光上传的代码均可运行,亲测可用,直接替换数据即可,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主或扫描博客文章底部QQ名片; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 图像融合:小波变换图像融合、遗传算法图像融合、IHS图像融合、PCA图像融合、curvelet变换图像融合、拉普拉斯金字塔+NSCT图像融合、医学图像图像融合、高分辨全色图像融合 DSIFT多聚焦图像融合、加权平均法图像融合、泊松彩色图像融合、主成分结合小波离散变换PCA-DWT图像融合、矩阵优化图像融合、导向滤波图像融合、拉普拉斯图像融合、系数绝对值最大图像融合

    基于ZCAM E2系列相机的OBS设计源码实现

    该项目为OBS直播软件的扩展设计源码,采用C++语言编写,并包含C、Shell和C等其他语言。源码共99个文件,其中包含16个头文件、11个PowerShell脚本、9个C++源文件、6个ZSH脚本、5个Shell脚本、5个输入文件、4个INI配置文件、3个YAML文件、3个文本文件、2个JSON文件。源码实现将ZCAM E2系列相机直接集成至OBS作为直播源,支持直播功能。

    VLOOKUP函数:在Excel中查找并返回数组特定元素的实用指南

    在Excel中处理数据时,我们经常需要从大量数据中提取特定的信息。VLOOKUP函数(垂直查找函数)是一个非常强大的工具,它可以帮助我们在数据表中查找并返回相应的值。本文将详细探讨如何使用VLOOKUP函数查找并返回数组中的特定元素,包括函数的语法、使用技巧和实际应用中的代码示例。 VLOOKUP函数是Excel中进行数据查找和提取的强大工具。通过使用VLOOKUP进行精确匹配、近似匹配、数组公式和反向查找,可以有效地从数组中查找并返回特定的元素。此外,使用IFERROR和数据类型检查可以提高数据查找的准确性和可靠性。通过这些技巧和方法,可以确保VLOOKUP函数在各种情况下都能准确无误地执行。

    拷贝到Windows 10的C:\Windows\System32或C:\Windows\SysWOW64,之后重启电脑

    拷贝到Windows 10的C:\Windows\System32或C:\Windows\SysWOW64,之后重启电脑

    excel统计分析(3): 一元线性回归分析

    excel统计分析(3): 一元线性回归分析

    基于matlab碳交易机制下考虑需求响应的优化运行【含Matlab源码 期】.zip

    CSDN海神之光上传的全部代码均可运行,亲测可用,直接替换数据即可,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作

    精简博客系统 基于Springboot和Mysql的精简博客系统代码(程序,中文注释)

    精简博客系统-精简博客系统-精简博客系统-精简博客系统-精简博客系统-精简博客系统-精简博客系统-精简博客系统-精简博客系统-精简博客系统-精简博客系统-精简博客系统 1、资源说明:精简博客系统源码,本资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 2、适用人群:计算机相关专业(如计算计、信息安全、大数据、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工等学习者,作为参考资料,进行参考学习使用。 3、资源用途:本资源具有较高的学习借鉴价值,可以作为“参考资料”,注意不是“定制需求”,代码只能作为学习参考,不能完全复制照搬。需要有一定的基础,能够看懂代码,能够自行调试代码,能够自行添加功能修改代码。 4. 最新计算机软件毕业设计选题大全(文章底部有博主联系方式): https://blog.csdn.net/2301_79206800/article/details/135931154 技术栈、环境、工具、软件: ① 系统环境:Windows ② 开发语言:Java ③ 框架:SpringBoot ④ 架构:B/S、MVC ⑤ 开发环境:IDE

    基于Scrapy框架的豆瓣电影爬虫系统

    项目介绍使用Scrapy框架爬取豆瓣电影,豆瓣选影视页面分别筛选地区为中国大陆、香港、台湾(可更换为其他地区),构造Ajax请求,获取电影id,再通过id构造电影链接,解析页面后获得电影详细数据,如名称、年份、导演、主演、类型等。 在IT行业中,网络爬虫是获取大量数据的重要手段,尤其在金融数据分析领域,如股票评论数据,能够为投资者提供宝贵的市场情绪参考。本项目聚焦于使用Python的Scrapy框架来批量爬取豆瓣电影网的数据,从而进行数据分析。 Scrapy是一个强大的Python爬虫框架,它提供了一整套解决方案,包括网页抓取、解析、数据存储等。使用Scrapy,我们可以高效地构建起一个完整的爬虫项目,其主要组件包括Spiders、Item、Item Pipeline、Downloader Middleware和Settings等。 1. **Spiders**:是Scrapy的核心,负责定义如何抓取数据以及如何处理抓取到的数据。在这个项目中,我们需要创建一个Spider,设置其起始URL(通常是豆瓣电影网的评论页面),并定义如何解析HTML页面,提取评论内容、用户名、

    基于c语言的配有图片和音乐的打字母游戏.zip

    基于c语言的配有图片和音乐的打字母游戏.zip

    基于asp.net的歌迷购物网设计与实现.docx

    基于asp.net的歌迷购物网设计与实现.docx

    基于Vue框架的hao123程序员网址导航设计源码

    该项目是一款基于Vue框架构建的程序员网址导航系统源码,包含136个文件,包括56个PNG图片、49个ICO图标、11个Vue组件文件、5个JavaScript文件以及少量JSON、YAML和其他配置文件。该系统以简洁明了的界面,为程序员提供便捷的网址导航服务。

    MPU6050 DMP文件移植包

    MPU6050 DMP文件移植包

    PyOpenGL-3.0.1 (2).zip

    opengl安装包

    螺旋轴泵3D模型图纸 Solidworks设计 附STEP格式.zip

    螺旋轴泵3D模型图纸 Solidworks设计 附STEP格式.zip

Global site tag (gtag.js) - Google Analytics