- 浏览: 69452 次
- 性别:
- 来自: 绍兴
最新评论
开发过程中经常碰到数据库更改的情况,在日常环境下如果每位开发人员连接的都是同一个库,那问题不算太大,修改代码上传后仅需修改该公共库即可,但是如果连的是本地个人的库那必须要把修改的sql语句发给其他开发者各自进行修改,这个工作是非常繁琐的;
liqiubase帮我们做了这些事情,通过xml配置的方式来增加修改表,添加数据等等操作,下面直接进入配置代码示例
首先需引入liqiubase的核心包
liquibase-core-1.9.5.jar
liqiubase的配置启用很简单,只需在spring配置文件中添加以下代码集合
dataSource是spring管理数据源,数据源指向一个库,liqiubase就是通过该数据源对库进行操作
然后就配置数据库操作了,比如我要创建一张权限表,我创建一个permissions.xml引入到spring
主要的标签就是changeSet每一次数据库操作就是一个changeSet,注意id不能重复
liqiubase会在我们库里面建几张它自己的表,当每次应用启动应用会去查id对应的changeSet是否被执行过,如果未执行就执行一遍然后记录.当其他开发人员下载到你的数据库操作配置后,liqiubase在他的库上发现你上次的changeSet没被执行过,就会执行一次
liqiubase对于统一管理数据库构建是非常方便的,平时上班空闲时都会自己搞搞例子,有时候要带回家做的话只需带走程序代码就行,到家里的电脑创建一个库就行,表结构和初始数据的创建都由liqiubase来搞定了,这就是一次配置终身受用啊.而且我个人比较喜欢用hibernate,hibernate的其中一个优点就是跨数据库,但如果构建数据库的语句已经写死了还怎么更改数据库呢
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的其中一个优点就是跨数据库,但如果构建数据库的语句已经写死了还怎么更改数据库呢
发表评论
-
Web开发学习13聊聊java反射
2016-07-12 18:41 762很喜欢一本叫《走出软件作坊》的书,其中有一句话让我较为深刻,“ ... -
Web开发学习12 浅谈设计模式
2016-07-01 13:33 1322在我刚接触 ... -
Web开发学习11 全局缓存控制
2015-10-12 14:27 743缓存用的好可以减少数据库的压力,在大并发的情况下极大的提升服务 ... -
Web开发学习10 hadoop实战
2015-10-09 14:02 758前一篇说到项目记录了很多埋点日志,当有一天项目需求需要对这些日 ... -
Web开发学习(9)全局埋点
2015-07-27 11:10 2018埋点的作用是把客户端每次访问服务端的操作记录下来,包括请求连接 ... -
Web开发学习8Struts2基类封装
2015-07-24 12:03 706一个好的基类可以帮助开发者减少很多开发工作,像我这种爱偷懒的人 ... -
Web开发学习7按钮级别权限控制
2015-07-23 16:21 13340这个功能的思路是自己原创的,没看过其他例子,其实是在做之前网上 ... -
浅列JavaEnum
2014-01-05 16:42 787enum Province{ ZHEJIANG,SHANGHA ... -
maven常用命令
2013-07-08 10:20 7911、创建普通Java项目: ... -
canvas绘制科赫雪花
2012-12-20 17:24 2158<html> <head> ... -
html5 audio与video方法属性事件概括
2012-12-20 14:46 1119play() 继续播放 pause() ... -
spring 整合mina
2012-12-20 11:48 1119首先定义自定义过滤器 <bean id=" ... -
Web开发学习(5)添加springsecurity应用
2011-12-14 15:00 961我学习公司这个架构多半就是为了把springsecurity搞 ... -
Web开发学习(4)添加spring应用
2011-12-14 14:45 797印象中似乎没做过不用spring的项目,因为它在web开发中的 ... -
Web开发学习(3)配置struts-tiles插件(附带json插件)
2011-12-05 15:22 2564struts的tiles插件是非常实用的,从某些方面可以很好的 ... -
使用线程删除导出临时文件
2011-12-01 16:33 2271项目支持大数据量导出e ... -
jQuery实现表格行点击选中复选框
2011-11-23 12:36 6000这个需求是在项目完成后客户提出的要求,看似简单但是还需要一点小 ... -
Web开发学习(2)配置convention插件
2011-11-04 10:28 1390注解的方式某些程度上能减少xml的配置量,个人感觉使程序更加清 ... -
Web开发学习(1)使用eclipse搭建maven项目
2011-10-20 10:04 5746首先用eclipse创建工程 ne ... -
数据库连接泛型基类创建
2011-06-30 11:49 999记录 以便以后参考---- 基类代码 public cl ...
相关推荐
ASP.NET Web开发学习实录光盘 视频文件太大,没有加入. 简介: ASP.NET是微软力推的Web开发编程技术,也是当今最热门的Web开发手段之一。ASP.NET 3.5技术提高了网络系统平台开发的效率和安全性,如新增匿名类型、...
Struts 2 Web开发学习实录
《PHP Web开发学习实录》
Python Web开发学习实录高清PDF(附书本全部源代码),适合学习Python,Python是目前流行的动态脚本语言之一。本书共15章,由浅入深、全面系统地介绍了使用Python语言进行程序开发的知识和技巧。
项目源码,适合学通java web作为实际开发项目的参考。
Delphi Web前端开发教程是针对想要使用TMS WEB Core框架创建Web应用程序的开发者,无论你是初学者还是高级开发者,本教程都提供了丰富的学习资源。TMS WEB Core框架是Delphi世界中的一大创新,它允许开发者使用...
"Python Web开发实录源代码"是针对这一主题的学习资料,通常包含一系列的示例项目和练习,旨在帮助开发者通过实践掌握Web开发的关键概念和技术。 首先,Python作为服务器端编程语言,其简洁的语法和强大的库支持...
《Python Web开发学习实录》完整版 第(1/2)分卷 高清扫描 PDF电子书
《Java Web 整合开发 完全自学手册》是一本深度探讨Java Web技术的书籍,由白广元编著。这本书旨在帮助读者全面掌握Java Web应用程序的开发技能,从基础到高级,涵盖了一系列核心概念和技术。通过源代码的学习,读者...
前段时间学习PHP 下了个PHP和MySQL Web开发(原书第4版)高清版,有将近200M,PDF文档不过没有书签,花了一天的时间将书签添加上去了,精确到了三级目录。 我没有权限上传200M的文件,所以放到百度空间了,下载后是...
《Web开发敏捷之道:应用Rails进行敏捷Web开发(第3版)》:Ruby on Rails是一个全套的MVC web框架,它能帮你开发高质量又美观的web应用,而且开发速度快得出乎你想象。你只须集中精力于应用程序本身,Rails就会帮你...
Web开发学习路线及示例,包括Web前端和后端的开发学习路线及项目示例。
【大华摄像头Web3.0二次开发WebPlugin详解】 大华摄像头Web3.0二次开发WebPlugin是一款专为开发者设计的工具,旨在帮助用户利用Web技术进行摄像头的高级功能定制和扩展。它允许开发者通过浏览器插件的方式,接入...
图书类型:pdg 本书探讨了Web应用程序开发中所涉及的... 本书适用于熟悉c#语言、使用C#语言进行过桌面应用程序开发,或使用ASP、PHP技术进行过web开发,并且希望学习使用NET和C#语言从事web开发的程序员。
这本书旨在帮助学习者深入理解Web前端开发的核心概念和技术,通过解决实际问题来巩固理论知识。 一、HTML基础 HTML(超文本标记语言)是网页制作的基础,它定义了网页的结构。储久良第三版教材中的答案可能包括各种...
本书详细介绍了在最新Tomcat 5版本上开发Java Web应用的各种技术。主要内容包括:Tomcat和Java Web开发的基础知识,Java Web开发的高级技术,Tomcat与当前其他通用软件的集成,以及Tomcat的各种高级功能。
总的来说,《C# Web开发者指南教程》是一本全面的指南,不仅适合完全没有编程背景的初学者,也适合有一定基础想要深入学习C# Web开发的读者。通过这本书,你可以学习到构建高效、可靠的Web应用所需的所有基础知识,...
web前端开发学习路径介绍
通过“Web开发技术(NET).doc”文档,初学者和学生可以深入学习这些概念,并通过一步步的实验操作,熟练掌握C#和ASP.NET在Web开发中的应用。这不仅有助于理论知识的理解,还有利于实践技能的提升,为未来的职业生涯...
vue+js+海康web开发包接入海康威视摄像头主要接口封装: 1、初始化插件 2、调整大小 3、登录 4、登出 5、获取设备基本信息 6、获取模拟通道 7、解析模拟通道XML内容 8、获取数字通道 9、解析数字通道XML内容 10、...