The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
SQL Structures for Workflow System
========================================

This directory contains the SQL structures necessary for using DBI
persistence for the Workflow system. Each file contains two or more
DDL statements for creating the tables and other support
structures. Typically you'll just need to pipe the file into the
relevant client:

MySQL (workflow_mysql.sql):

  mysql -u user -p password databasename < workflow_mysql.sql

PostgreSQL (workflow_pg.sql):

  psql -U user -f workflow_pg.sql databasename

SQLite (workflow_sqlite.sql):

  sqlite dbfile.db < workflow_sqlite.sql

For other databases use the generic file 'workflow_other.sql'. The
only difference between it and the other types is how the ID fields
are created. The previous three use vendor-specific methods for
generating ID fields while the generic version just uses a random
eight-character string. Less readable but still unique.

Also, there's a 'workflow_csv.sql' for delimited text files. There's
no 'csv' client to create and manipulate such databases, so you can
just use this:

 my $dbh = DBI->connect( 'DBI:CSV:f_dir=.', '', '' );
 open( SQL, '<', 'struct/workflow_csv.sql' )
     || die "Cannot open SQL for CSV: $!";
 my $content = join( '', <SQL> );
 close( SQL );
 my @tables = split( ';', $content );
 foreach my $table ( @tables ) {
     next if ( $table =~ /^\s*$/ );
     warn "Creating table with SQL: $table\n";
     $dbh->do( $table );
 }

========================================
$Id: README,v 1.3 2004/05/14 05:13:13 cwinters Exp $