`
sdh88hf
  • 浏览: 69445 次
  • 性别: Icon_minigender_1
  • 来自: 绍兴
社区版块
存档分类
最新评论

Web开发学习6添加liqiubase

阅读更多
开发过程中经常碰到数据库更改的情况,在日常环境下如果每位开发人员连接的都是同一个库,那问题不算太大,修改代码上传后仅需修改该公共库即可,但是如果连的是本地个人的库那必须要把修改的sql语句发给其他开发者各自进行修改,这个工作是非常繁琐的;

liqiubase帮我们做了这些事情,通过xml配置的方式来增加修改表,添加数据等等操作,下面直接进入配置代码示例
首先需引入liqiubase的核心包
liquibase-core-1.9.5.jar

liqiubase的配置启用很简单,只需在spring配置文件中添加以下代码集合

 <!-- 配置liqiubase -->
	<bean id="liquibase" class="liquibase.spring.SpringLiquibase">  
        <property name="dataSource" ref="dataSource" />  
        <property name="changeLog" value="classpath:changelog.xml" /> 
    </bean>


dataSource是spring管理数据源,数据源指向一个库,liqiubase就是通过该数据源对库进行操作

然后就配置数据库操作了,比如我要创建一张权限表,我创建一个permissions.xml引入到spring


<databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog/1.9" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog/1.9 http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-1.9.xsd">
	<changeSet author="admin" id="permissions-10005">
        <createTable tableName="permissions">  
            <column name="id" type="bigint">  
                <constraints nullable="false" primaryKey="true" />  
            </column>  
            <column name="name" type="varchar(32)" />
            <column name="actionurl" type="varchar(256)" /> 
            <column name="jsurl" type="varchar(256)" />
            <column name="level" type="int" />
            <column name="parentid" type="bigint"/>
            <column name="ordernum" type="int" defaultValue="0"/>  
        </createTable>
        
        <insert tableName="permissions">
        	<column name="id" value="1"/>  
            <column name="name" value="用户管理" />
            <column name="level" value="1" />
            <column name="parentid" value="-1"/>
            <column name="ordernum" value="1"/>
        </insert>
</changeSet>
</databaseChangeLog>

主要的标签就是changeSet每一次数据库操作就是一个changeSet,注意id不能重复
liqiubase会在我们库里面建几张它自己的表,当每次应用启动应用会去查id对应的changeSet是否被执行过,如果未执行就执行一遍然后记录.当其他开发人员下载到你的数据库操作配置后,liqiubase在他的库上发现你上次的changeSet没被执行过,就会执行一次

liqiubase对于统一管理数据库构建是非常方便的,平时上班空闲时都会自己搞搞例子,有时候要带回家做的话只需带走程序代码就行,到家里的电脑创建一个库就行,表结构和初始数据的创建都由liqiubase来搞定了,这就是一次配置终身受用啊.而且我个人比较喜欢用hibernate,hibernate的其中一个优点就是跨数据库,但如果构建数据库的语句已经写死了还怎么更改数据库呢
分享到:
评论

相关推荐

    ASP.NET Web开发学习实录光盘

    ASP.NET Web开发学习实录光盘 视频文件太大,没有加入. 简介: ASP.NET是微软力推的Web开发编程技术,也是当今最热门的Web开发手段之一。ASP.NET 3.5技术提高了网络系统平台开发的效率和安全性,如新增匿名类型、...

    Struts 2 Web开发学习实录

    Struts 2 Web开发学习实录

    PHP Web开发学习实录

    《PHP Web开发学习实录》

    Python Web开发学习实录高清PDF(附书本全部源代码)

    Python Web开发学习实录高清PDF(附书本全部源代码),适合学习Python,Python是目前流行的动态脚本语言之一。本书共15章,由浅入深、全面系统地介绍了使用Python语言进行程序开发的知识和技巧。

    java web开发学习手册光盘中的5个项目源码

    项目源码,适合学通java web作为实际开发项目的参考。

    Delphi+Web前端开发教程基于TMS+WEB+Core框架.pdf

    Delphi Web前端开发教程是针对想要使用TMS WEB Core框架创建Web应用程序的开发者,无论你是初学者还是高级开发者,本教程都提供了丰富的学习资源。TMS WEB Core框架是Delphi世界中的一大创新,它允许开发者使用...

    python web开发实录源代码

    "Python Web开发实录源代码"是针对这一主题的学习资料,通常包含一系列的示例项目和练习,旨在帮助开发者通过实践掌握Web开发的关键概念和技术。 首先,Python作为服务器端编程语言,其简洁的语法和强大的库支持...

    Python Web开发学习实录.part1.rar 高清扫描 PDF电子书

    《Python Web开发学习实录》完整版 第(1/2)分卷 高清扫描 PDF电子书

    Java Web 整合开发 完全自学手册 源代码

    《Java Web 整合开发 完全自学手册》是一本深度探讨Java Web技术的书籍,由白广元编著。这本书旨在帮助读者全面掌握Java Web应用程序的开发技能,从基础到高级,涵盖了一系列核心概念和技术。通过源代码的学习,读者...

    PHP和MySQL Web开发(原书第4版)带书签

    前段时间学习PHP 下了个PHP和MySQL Web开发(原书第4版)高清版,有将近200M,PDF文档不过没有书签,花了一天的时间将书签添加上去了,精确到了三级目录。 我没有权限上传200M的文件,所以放到百度空间了,下载后是...

    Web开发敏捷之道-应用Rails进行敏捷Web开发(第3版).pdf

    《Web开发敏捷之道:应用Rails进行敏捷Web开发(第3版)》:Ruby on Rails是一个全套的MVC web框架,它能帮你开发高质量又美观的web应用,而且开发速度快得出乎你想象。你只须集中精力于应用程序本身,Rails就会帮你...

    Web开发学习路线及示例

    Web开发学习路线及示例,包括Web前端和后端的开发学习路线及项目示例。

    大华摄像头web3.0二次开发webplugin

    【大华摄像头Web3.0二次开发WebPlugin详解】 大华摄像头Web3.0二次开发WebPlugin是一款专为开发者设计的工具,旨在帮助用户利用Web技术进行摄像头的高级功能定制和扩展。它允许开发者通过浏览器插件的方式,接入...

    web前端开发技术储久良第三版答案

    这本书旨在帮助学习者深入理解Web前端开发的核心概念和技术,通过解决实际问题来巩固理论知识。 一、HTML基础 HTML(超文本标记语言)是网页制作的基础,它定义了网页的结构。储久良第三版教材中的答案可能包括各种...

    Tomcat与Java.Web开发技术详解(PDF)

    本书详细介绍了在最新Tomcat 5版本上开发Java Web应用的各种技术。主要内容包括:Tomcat和Java Web开发的基础知识,Java Web开发的高级技术,Tomcat与当前其他通用软件的集成,以及Tomcat的各种高级功能。

    C#web开发者指南教程PDF(含源代码),很适合入门学习C#web制作web应用程序。附带源代码。

    总的来说,《C# Web开发者指南教程》是一本全面的指南,不仅适合完全没有编程背景的初学者,也适合有一定基础想要深入学习C# Web开发的读者。通过这本书,你可以学习到构建高效、可靠的Web应用所需的所有基础知识,...

    web前端与移动开发学习路径

    web前端开发学习路径介绍

    Web开发技术(C#篇)

    通过“Web开发技术(NET).doc”文档,初学者和学生可以深入学习这些概念,并通过一步步的实验操作,熟练掌握C#和ASP.NET在Web开发中的应用。这不仅有助于理论知识的理解,还有利于实践技能的提升,为未来的职业生涯...

    vue+js+海康web开发包接入海康威视摄像头

    vue+js+海康web开发包接入海康威视摄像头主要接口封装: 1、初始化插件 2、调整大小 3、登录 4、登出 5、获取设备基本信息 6、获取模拟通道 7、解析模拟通道XML内容 8、获取数字通道 9、解析数字通道XML内容 10、...

    Tomcat与Java Web开发技术详解(第2版).pdf

    《Tomcat与Java Web开发技术详解(第2版)》是一本深入探讨Java Web应用程序部署和运行环境的权威指南。本书主要围绕Apache Tomcat服务器展开,涵盖了从基础概念到高级特性的全方位讲解,旨在帮助读者掌握Java Web...

Global site tag (gtag.js) - Google Analytics