Samuel Learning

  • 联系
  •  
  • 管理

文章分类(203)

  • 01 ASP/HTML(6)
  • 02 Script/CSS(16)
  • 03 C/C++
  • 04 XML(4)
  • 05 微软编程(26)
  • 06 J2EE(60)
  • 09 Linux(14)
  • 10 Database(27)
  • 11 报表打印
  • 12 打包安装(1)
  • 13 模式重构(2)
  • 14 系统架构
  • 15 敏捷开发(11)
  • 16 案例分析(30)
  • 17 Workflow(1)
  • 18 配置管理(1)
  • 19 项目管理
  • 20 英语(4)

新闻分类(52)

  • CXF学习
  • Hibernate学习(1)
  • iBatis学习(16)
  • Struts1学习(1)
  • Struts2学习(34)

.NET资源

  • adxmenu
  • C# Open Source
  • DNN Directory
  • M2Land
  • Windows Form FAQ
  • 中国DNN
  • 中国DNN联盟

Ajax

  • DoJo
  • GWT
  • JQuery
  • jquery autocomplete
  • jquery flexgrid
  • JQuery Form
  • jquery masked input
  • JQuery UI
  • jquery validation
  • Jquery 图表
  • jquery报表
  • jquery插件集合
  • Qooxdoo
  • Tibco GI
  • YUI
  • YUI-EXT
  • ZeroKode

Java开源

  • ABLE
  • Agile Tao
  • Ajax4JSF
  • Alfresco
  • AppFuse
  • Compiere
  • Equinox
  • Findbugs
  • Geronimo
  • Grails
  • Harmony
  • Hibernate论坛
  • JAG
  • Java开源大全
  • Java视线论坛
  • jBPM工作流
  • JSFTutorials
  • Nereide ERP
  • Ofbiz ERP
  • Opentaps ERP
  • operamasks
  • Petstore
  • Prototype.js
  • RIFE
  • Runa
  • SpringSide
  • Struts Menu
  • Sun Glassfish
  • Trails
  • YUI4JSF
  • 满江红

Mobile

  • Sencha

WEB资源

  • DHTML中心
  • DHTML参考手册
  • DHTML文档
  • EclipsePlugin
  • Firebug
  • GRO Clinux
  • jMaki
  • JSTL文档
  • LoadIcon
  • Openlaszlo
  • Struts Menu 展示
  • Web Test Tools
  • WebCtrs
  • Webdeveloper
  • 中国RIA开发者论坛

Workflow

  • E-Workflow
  • JBPM
  • OpenWFE
  • OSWorkflow
  • WFMC
  • Workflow Research

其他连接

  • confach
  • CPP
  • ejay
  • Giovanni
  • 丹佛
  • 交大e-learning
  • 交大研究生院
  • 可恶的猫
  • 天天@blog
  • 我的相册
  • 阿飞

大牛人

  • 32篇JBPM
  • David.Turing
  • HongSoft@业务集成
  • Joel
  • Koen Aers
  • Martinfowler
  • Raible Matt
  • Raible Wiki
  • Scott W.Ambler
  • Tom Baeyens
  • Uncle Bob
  • 一个世界在等待
  • 子在川上曰
  • 小布老师
  • 小明
  • 差沙
  • 徐昊
  • 江南白衣
  • 汪博士
  • 汪小金
  • 银狐999

开源软件

  • 2Bizbox ERP
  • CompiereCRM&ERP
  • EGW
  • Vtiger CRM
  • webERP

敏捷

  • Canoo
  • Cruisecontrol
  • DBUnit
  • EL4Ant
  • Extreme Programming
  • Fit
  • Fitnesse
  • JFrog
  • Liquibase
  • Maven
  • MockObjects
  • Selenium
  • Squish
  • xpairtise
  • XPlanner
  • XProgramming
  • 敏捷联盟

数据库

  • Oracle 中国
  • Oracle-ERP
  • Oracle在线社区

未归类

  • Aquarius Orm Studio
  • mambo建站系统
  • Oracle产品下载
  • 远程同步管理工具Capivara

经典框架

  • Apache Shale
  • formdef-struts
  • FreeMarker 主页
  • JBoss Seam
  • JSF 中心
  • JSF 入门应用
  • JSF中国
  • MyFaces官方
  • Spring 社区
  • Spring专业网站
  • Spring中文论坛
  • Spring参考手册
  • Spring官方网站
  • strecks-struts
  • Struts1
  • Struts2
  • Struts-layout
  • StrutsWiKi
  • Tapestry WIKI
  • Tapestry 官方
  • Tapestry4开发指南
  • Tapestry中文文档
  • Webwork2文档
  • Wicket

网络教程

  • Laliluna
  • RoseIndia
  • Sang Shin
  • Visualbuilder

著名站点

  • Buildix
  • Dev2Dev
  • IBM dev中国
  • InfoQ
  • ITPub
  • Java Eye
  • Java Research
  • JavaRead
  • JavaWorldTW
  • Matrix
  • PHP100
  • PHPX
  • SpringSideWiKi
  • TheServerSide
  • TWPHP
  • 中国工作流论坛

项目管理

  • 管理人网

最新评论

View Post

ant 启动关闭和管理hsqldb的配置

 <target name="dbmanager" description="Start HSQLDB Manager">
        
<java classname="org.hsqldb.util.DatabaseManagerSwing"
              fork
="yes"
              classpathref
="build.classpath"
              failonerror
="true">
            
<arg value="-url"/>
            
<arg value="jdbc:hsqldb:hsql://localhost/"/>
            
<arg value="-driver"/>
            
<arg value="org.hsqldb.jdbcDriver"/>
        
</java>

    
</target>


    
<target name="dbstartup" description="Start the Hsqldb database server">
        
<java classname="org.hsqldb.Server" fork="yes" classpathref="build.classpath" failonerror="true"/>
    
</target>

    
<taskdef name="shutdownTask" classname="ShutdownTask" classpathref="build.classpath"/>

    
<target name="dbshutdown" description="Stop the Hsqldb database server">
        
<shutdownTask driver="org.hsqldb.jdbcDriver" url="jdbc:hsqldb:hsql://localhost/" userid="sa" password=""
                      sqlCommand
="SHUTDOWN COMPACT" msg="MyShutdownTask"/>
    
</target>

其中shutdownTask依赖于自定义的Task类,代码如下:
//ShutdownTask.java
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import org.apache.tools.ant.BuildException;
import org.apache.tools.ant.Task;
 
/**
 *ShutdownTask:AntTaskforshutdowntheHsqldbserver.
 *
 *@authorYuLimin
 
*/
publicclass ShutdownTask 
extends Task
{
      
// Defaut Value
      private String msg = "ShutdownTask";
      
private String driver = "org.hsqldb.jdbcDriver";
      
private String url = "jdbc:hsqldb:hsql://localhost/";
      
private String userid = "sa";
      
private String password = "";
      
private String sqlCommand = "SHUTDOWN";
 
      
public ShutdownTask()
      {
            
super();
      }
 
      
/**
       *ForTest
       *
       *@paramargv
       *@throwsException
       
*/
      publicstaticvoid main(
final String[] argv)
      {
            
final ShutdownTask shutdownTask = new ShutdownTask();
            shutdownTask.shutdown();
      }
 
      
/**
       *Themethodexecutingthetask
       
*/
      publicvoid execute() 
throws BuildException
      {
            System.out.println(msg 
+ " Begin");
            System.out.println(
"Driver=" + getDriver());
            System.out.println(
"URL=" + getUrl());
            System.out.println(
"Userid=" + getUserid());
            System.out.println(
"Password=" + getPassword());
            System.out.println(
"SqlCommand=" + getSqlCommand());
            shutdown();
            System.out.println(msg 
+ " End");
            System.out.println();
      }
 
      
/**
       *Shutdownthedatabase
       
*/
      publicvoid shutdown()
      {
            Connection connection 
= null;
            Statement statement 
= null;
            
try
            {
                  Class.forName(getDriver());
                  connection 
= DriverManager.getConnection(getUrl(),getUserid(),getPassword());
                  statement 
= connection.createStatement();
                  statement.execute(getSqlCommand());
                  statement.close();
                  connection.close();
            }
            
catch(Exception e)
            {
                  e.printStackTrace();
                  thrownew RuntimeException(e);
            }
            
finally
            {
                  
if(statement != null)
                  {
                        
try
                        {
                              statement.close();
                        }
                        
catch(SQLException e)
                        {
                              thrownew RuntimeException(e);
                        }
                  }
                  
if(connection != null)
                  {
                        
try
                        {
                              connection.close();
                        }
                        
catch(SQLException e)
                        {
                              thrownew RuntimeException(e);
                        }
                  }
            }
      }
 
      
// More accessor method : setter & getter
      publicvoid setMsg(final String msg)
      {
            
this.msg = msg;
      }
 
      publicvoid setDriver(
final String driver)
      {
            
this.driver = driver;
      }
 
      publicvoid setPassword(
final String password)
      {
            
this.password = password;
      }
 
      publicvoid setUrl(
final String url)
      {
            
this.url = url;
      }
 
      publicvoid setUserid(
final String userid)
      {
            
this.userid = userid;
      }
 
      publicvoid setSqlCommand(
final String sqlCommand)
      {
            
this.sqlCommand = sqlCommand;
      }
 
      
public String getDriver()
      {
            returndriver;
      }
 
      
public String getPassword()
      {
            returnpassword;
      }
 
      
public String getUrl()
      {
            returnurl;
      }
 
      
public String getUserid()
      {
            returnuserid;
      }
 
      
public String getSqlCommand()
      {
            returnsqlCommand;
      }
 
      
public String getMsg()
      {
            returnmsg;
      }
}

调用说明:
  <!-- Classpath declaration -->
      
<pathid="hsqldb.classpath">
            
<filesetdir="${lib.dir}">
                  
<includename="**/hsqldb.jar"/>
                  
<includename="**/ShutdownTask.jar"/>
            
</fileset>
      
</path>
 
      
<!-- Shutdown the Hsqldb database server via ShutdownTask -->
      
<targetname="dbshutdownTask"description="Shutdown the Hsqldb database server via ShutdownTask">
            
<!-- Define ShutdownTask -->
            
<taskdefname="shutdownTask"classname="ShutdownTask"classpathref="hsqldb.classpath"/>
            
<!-- Call ShutdownTask -->
            
<!-- Default ShutdownTask, only like this -->
            
<!-- <shutdownTask/> -->
            
<!-- Sample MyShutdownTask -->
            
<!-- <shutdownTask driver="org.hsqldb.jdbcDriver" url="jdbc:hsqldb:hsql://localhost/"
                 userid="sa" password="" sqlCommand="SHUTDOWN" msg="MyShutdownTask"/> 
-->
            
<!-- Sample MyShutdownTask SHUTDOWN COMPACT -->
            
<!-- <shutdownTask driver="org.hsqldb.jdbcDriver" url="jdbc:hsqldb:hsql://localhost/"
                   userid="sa" password="" sqlCommand="SHUTDOWN COMPACT" msg="MyShutdownTask"/> 
-->
            
<!-- Sample MyShutdownTask SHUTDOWN IMMEDIATELY -->
            
<shutdownTaskdriver="org.hsqldb.jdbcDriver"url="jdbc:hsqldb:hsql://localhost/"userid="sa"
                password
=""sqlCommand="SHUTDOWN IMMEDIATELY"msg="MyShutdownTask"/>
      
</target>

如果是命令行上启动了hsqldb,直接Ctl+C就可以结束掉它,几秒钟后就生效。






posted on 2007-06-03 03:11 MingIsMe 阅读(483) 评论(0)  编辑  收藏 所属分类: 15 敏捷开发

 
Powered by:
BlogJava
Copyright © MingIsMe