Generate SQL script for db using dbdeploy schema version table and delta scripts

author Luke Crouch at SourceForge (http://sourceforge.net)
version $Id: c5a3ef3c4fbb1896df2b223194a8e372a8b5649c $
package phing.tasks.ext.dbdeploy
copyright 2001,2002 THYRELL. All rights reserved

 Methods

Add a new fileset.

createFileSet() : \FileSet

Returns

Returns the textual description of the task

getDescription() : string
Inherited
inherited_from \Task::getDescription()

Returns

stringThe text description of the task

Returns the location within the buildfile this task occurs.

getLocation() : \Location
Inherited

Used by BuildException to give detailed error messages.

inherited_from \Task::getLocation()

Returns

\LocationThe location object describing the position of this task within the buildfile.

Returns the owning target of this task.

getOwningTarget() : \Target
Inherited
inherited_from \Task::getOwningTarget()

Returns

\TargetThe target object that owns this task

Returns a reference to current project

getProject() : \Project
Inherited
inherited_from \ProjectComponent::getProject()
inherited_from \Task::getProject()

Returns

\ProjectReference to current porject object

Returns the wrapper object for runtime configuration

getRuntimeConfigurableWrapper() : \RuntimeConfigurable
Inherited
inherited_from \Task::getRuntimeConfigurableWrapper()

Returns

\RuntimeConfigurableThe wrapper object used by this task

Returns the name of task, used only for log messages

getTaskName() : string
Inherited
inherited_from \Task::getTaskName()

Returns

stringName of this task

Returns the name of the task under which it was invoked, usually the XML tagname

getTaskType() : string
Inherited
inherited_from \Task::getTaskType()

Returns

stringThe type of this task (XML Tag)

Called by the parser to let the task initialize properly.

init() 
Inherited

Should throw a BuildException if something goes wrong with the build

This is abstract here, but may not be overloaded by subclasses.

inherited_from \Task::init()

Exceptions

\BuildException

Provides a project level log event to the task.

log(string $msg, integer $level) 
Inherited
see \BuildEvent
see \BuildListener
inherited_from \Task::log()

Parameters

$msg

string

The message to log

$level

integer

The priority of the message

The main function for the task

main() : void

This method may be called more than once, if the task is invoked more than once. For example, if target1 and target2 both depend on target3, then running phing target1 target2 will run all tasks in target3 twice.

Should throw a BuildException if someting goes wrong with the build

This is abstract here. Must be overloaded by real tasks.

Exceptions

\BuildException

Configure this task if it hasn't been done already.

maybeConfigure() 
Inherited
inherited_from \Task::maybeConfigure()

Perfrom this task

perform() 
Inherited
inherited_from \Task::perform()

Set the appliedBy property

setAppliedBy(string $appliedBy) : void

Parameters

$appliedBy

string

Set the checkall property

setCheckAll(bool $checkall) : void

Parameters

$checkall

bool

Set the deltaset property

setDeltaSet(string $deltaSet) : void

Parameters

$deltaSet

string

Sets a textual description of the task

setDescription(string $desc) 
Inherited
inherited_from \Task::setDescription()

Parameters

$desc

string

The text describing the task

Set the directory where to find the patchfiles

setDir(string $dir) : void

Parameters

$dir

string

Set the lastchangetoapply property

setLastChangeToApply(int $lastChangeToApply) : void

Parameters

$lastChangeToApply

int

Sets the location within the buildfile this task occurs.

setLocation(\Location $location) 
Inherited

Called by the parser to set location information.

inherited_from \Task::setLocation()

Parameters

$location

\Location

The location object describing the position of this task within the buildfile.

Set the outputfile which contains all patch sql statements for this deployment

setOutputFile(string $outputFile) : void

Parameters

$outputFile

string

Sets the owning target this task belongs to.

setOwningTarget(\Target $target) 
Inherited
inherited_from \Task::setOwningTarget()

Parameters

$target

\Target

Reference to owning target

Set the password for the database connection

setPassword(string $password) : void

Parameters

$password

string

References the project to the current component.

setProject(\Project $project) 
Inherited
inherited_from \ProjectComponent::setProject()
inherited_from \Task::setProject()

Parameters

$project

\Project

The reference to the current project

Sets the wrapper object this task should use for runtime configurable elements.

setRuntimeConfigurableWrapper(\RuntimeConfigurable $wrapper) 
Inherited
inherited_from \Task::setRuntimeConfigurableWrapper()

Parameters

$wrapper

\RuntimeConfigurable

The wrapper object this task should use

Sets the name of this task for log messages

setTaskName(string $name) : string
Inherited
inherited_from \Task::setTaskName()

Parameters

$name

string

Returns

stringA string representing the name of this task for log

Sets the type of the task.

setTaskType(string $name) 
Inherited

Usually this is the name of the XML tag

inherited_from \Task::setTaskType()

Parameters

$name

string

The type of this task (XML Tag)

Set the undo outputfile which contains all undo statements for this deployment

setUndoOutputFile(string $undoOutputFile) : void

Parameters

$undoOutputFile

string

Set the url for the database connection

setUrl(string $url) : void

Parameters

$url

string

Set the userid for the database connection

setUserId(string $userid) : void

Parameters

$userid

string

Generate the sql for doing/undoing the deployment and write it to a file

createOutputFile(string $file, bool $undo) : void

Parameters

$file

string

$undo

bool

Create the deploy and undo deploy outputfiles

deploy() : void

Determine if this patch file need to be deployed (using fileChangeNumber, lastChangeAppliedInDb and $this->checkall)

fileNeedsToBeRead(int $fileChangeNumber, string $lastChangeAppliedInDb) : bool

Parameters

$fileChangeNumber

int

$lastChangeAppliedInDb

string

Returns

boolTrue or false if patch file needs to be deployed

Generate the sql for doing/undoing this deployment

generateSql(bool $undo) : string

Parameters

$undo

bool

Returns

stringThe sql

Get the numbers of all the patches that are already applied according to the changelog table in the database

getAppliedChangeNumbers() : array

Returns

array

Get a list of all the patch files in the patch file directory

getDeltasFilesArray() : array

Returns

array

Get the number of the last patch applied to the database

getLastChangeAppliedInDb() : int | mixed

Returns

intmixedThe highest patch number that is applied in the db

Returns a name

getRegisterSlot(string $slotName) 
Inherited
inherited_from \Task::getRegisterSlot()

Parameters

$slotName

string

Sort files in the patch files directory (ascending or descending depending on $undo boolean)

sortFiles(array $files, bool $undo) : void

Parameters

$files

array

$undo

bool

 Properties

 

$TABLE_NAME : string
 

$appliedBy : string
 

$appliedChangeNumbers : array
 

$checkall : int
 

$dbmsSyntax : object
 

$deltaSet : string
 

$description : string
Inherited
inherited_from \Task::$$description
 

$dir : string
 

$lastChangeToApply : int
 

$location : \Location
Inherited
inherited_from \Task::$$location
 

$outputFile : string
 

$password : string
 

$project : \Project
Inherited
inherited_from \ProjectComponent::$$project
inherited_from \Task::$$project
 

$target : \Target
Inherited
inherited_from \Task::$$target
 

$taskName : string
Inherited
inherited_from \Task::$$taskName
 

$taskType : string
Inherited
inherited_from \Task::$$taskType
 

$undoOutputFile : string
 

$url : string
 

$userid : string
 

$wrapper : \RuntimeConfigurable
Inherited
inherited_from \Task::$$wrapper