NAME
Meta::Db::Type - Object to store a database type information in it.
COPYRIGHT
Copyright (C) 2001, 2002 Mark Veltzer; All rights reserved.
LICENSE
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.
DETAILS
MANIFEST: Type.pm
PROJECT: meta
VERSION: 0.42
SYNOPSIS
package foo;
use Meta::Db::Type qw();
my($type)=Meta::Db::Type->new();
$type->set("String",0,0,0,0);
DESCRIPTION
This is an object to store database type information in it. All types of information are in here.
FUNCTIONS
BEGIN()
is_prim($)
is_inde($)
is_set($)
is_enum($)
print($$)
printd($$)
printx($$)
getsql_create($$$)
getsql_drop($$$)
getsql_names($$)
getsql_bind($$)
FUNCTION DOCUMENTATION
- BEGIN()
-
This method initializes the module for work. Do not use it directly. The idea is that this module uses translation hashes of types extensivly and we could build them once and use them many times. In addition this method sets up accessor methods for the following attributes: "name", "set_ref", "enum_ref", "table_ref", "field_ref", "optimized", "null".
- is_prim($)
-
This returns whether the type is a primary key or not for this table.
- is_inde($)
-
This returns whether the type is an index to another table or not.
- is_set($)
-
This returns whether the type is a set type or not.
- is_enum($)
-
This returns whether the type is an enum type or not.
- print($$)
-
This prints out the current type object.
- printd($$)
-
This method prints out the object in DocBook XML format using the a writer object received.
- printx($$)
-
This method prints out the object in XML format using the a writer object received.
- getsql_create($$$)
-
This method will add SQL statements to a container of SQL statements which is recevied which create this type on the database.
- getsql_drop($$$)
-
This method will add SQL statements to a container of SQL statements which is recevied which drop this type on the database.
- getsql_names($$)
-
This method will return an SQL string which describes the type and which is fit for inclusion in an SQL CREATE TABLE type statement.
- getsql_bind($$)
-
This method returns the DBI parameter suitable for inclusion in "bind_param" type DBI statements.
BUGS
None.
AUTHOR
Name: Mark Veltzer
Email: mark2776@yahoo.com
WWW: http://www.geocities.com/mark2776
CPAN id: VELTZER
HISTORY
0.00 MV initial code brought in
0.01 MV bring databases on line
0.02 MV ok. This is for real
0.03 MV make quality checks on perl code
0.04 MV more perl checks
0.05 MV check that all uses have qw
0.06 MV fix todo items look in pod documentation
0.07 MV more on tests/more checks to perl
0.08 MV change new methods to have prototypes
0.09 MV perl code quality
0.10 MV more perl quality
0.11 MV more perl quality
0.12 MV perl documentation
0.13 MV get graph stuff going
0.14 MV more perl quality
0.15 MV perl qulity code
0.16 MV more perl code quality
0.17 MV revision change
0.18 MV languages.pl test online
0.19 MV history change
0.20 MV db stuff
0.21 MV web site stuff
0.22 MV more data sets
0.23 MV spelling and papers
0.24 MV perl packaging
0.25 MV PDMT
0.26 MV pictures database
0.27 MV tree type organization in databases
0.28 MV some chess work
0.29 MV more movies
0.30 MV books XML into database
0.31 MV md5 project
0.32 MV database
0.33 MV perl module versions in files
0.34 MV movies and small fixes
0.35 MV movie stuff
0.36 MV md5 progress
0.37 MV more Class method generation
0.38 MV more thumbnail code
0.39 MV more thumbnail stuff
0.40 MV thumbnail user interface
0.41 MV import tests
0.42 MV more thumbnail issues
SEE ALSO
Nothing.
TODO
-add auto_increment ?!?
-IpMask and Ip types could limit the size of the text to some limit (12 bytes ? 15 bytes ?)
-make the null attribute a binary value.
-make the print to SGML method write the null and default stuff too (revamp it altogether).
-why is the index created separately ? can't I create it with CREATE TABLE ?