Scroll to navigation

Parse::Dia::SQL::Output::SQLite3fk(3pm) User Contributed Perl Documentation Parse::Dia::SQL::Output::SQLite3fk(3pm)
 

NAME

Parse::Dia::SQL::Output::SQLite3fk - Create SQL for SQLite version 3, with foreign key support

SYNOPSIS

    use Parse::Dia::SQL;
    my $dia = Parse::Dia::SQL->new(file => 'foo.dia', db => 'sqlite3fk');
    print $dia->get_sql();

DESCRIPTION

This sub-class creates SQL for the SQLite database version 3.

new

The constructor.
Object names in SQLite have no inherent limit. 60 has been arbitrarily chosen.

_get_create_table_sql

Generate create table statement for a single table using SQLite syntax:
Includes class comments before the table definition.
Includes autoupdate triggers based on the class comment.
Includes foreign key support of the form
  foreign key(thisColumn)  references thatTable(thatColumn) {action}
Where {action} is the optional contraint condition, such as 'on delete cascade' exactly as entered in the diagram.
autoupdate triggers
If the class comment includes a line like:
<autoupdate: foo/>
Then an 'after update' trigger is generated for this table which executes the statement foo for the updated row.
Examples of use include tracking record modification dates ("<autoupdate:dtModified=datetime('now')/">) or deriving a value from another field ("<autoupdate:sSoundex=soundex(sName)/">)

_create_pk_string

Override default functon to include foreign key clauses

get_schema_drop

Generate drop table statments for all tables using SQLite syntax:
  drop table {foo} if exists

get_view_drop

Generate drop view statments for all tables using SQLite syntax:
  drop view {foo} if exists

_get_fk_drop

Foreign key enforcement is embedded in the table definitions for SQLite, so no output is required here.

_get_drop_index_sql

drop index statement using SQLite syntax:
  drop index {foo} if exists

get_permissions_create

SQLite doesn't support permissions, so suppress this output.

get_permissions_drop

SQLite doesn't support permissions, so suppress this output.

_get_create_association_sql

Foreign key enforcement is embedded in the table definitions for SQLite, so no output is required here.

TODO

Things that might get added in future versions:
Views
Views haven't been tested. They might already work, but who knows...
Other stuff
Bugs etc
2014-01-03 perl v5.18.1