1DBIx::Admin::TableInfo(U3s)er Contributed Perl DocumentatDiBoInx::Admin::TableInfo(3)
2
3
4
6 DBIx::Admin::TableInfo - A wrapper for all of table_info(),
7 column_info(), *_key_info()
8
10 This is scripts/synopsis.pl:
11
12 #!/usr/bin/env perl
13
14 use strict;
15 use warnings;
16
17 use DBI;
18 use DBIx::Admin::TableInfo 3.02;
19
20 use Lingua::EN::PluralToSingular 'to_singular';
21
22 use Text::Table::Manifold ':constants';
23
24 # ---------------------
25
26 my($attr) = {};
27 $$attr{sqlite_unicode} = 1 if ($ENV{DBI_DSN} =~ /SQLite/i);
28 my($dbh) = DBI -> connect($ENV{DBI_DSN}, $ENV{DBI_USER}, $ENV{DBI_PASS}, $attr);
29 my($vendor_name) = uc $dbh -> get_info(17);
30 my($info) = DBIx::Admin::TableInfo -> new(dbh => $dbh) -> info;
31
32 $dbh -> do('pragma foreign_keys = on') if ($ENV{DBI_DSN} =~ /SQLite/i);
33
34 my($temp_1, $temp_2, $temp_3);
35
36 if ($vendor_name eq 'MYSQL')
37 {
38 $temp_1 = 'PKTABLE_NAME';
39 $temp_2 = 'FKTABLE_NAME';
40 $temp_3 = 'FKCOLUMN_NAME';
41 }
42 else # ORACLE && POSTGRESQL && SQLITE (at least).
43 {
44 $temp_1 = 'UK_TABLE_NAME';
45 $temp_2 = 'FK_TABLE_NAME';
46 $temp_3 = 'FK_COLUMN_NAME';
47 }
48
49 my(%special_fk_column) =
50 (
51 spouse_id => 'person_id',
52 );
53
54 my($destination_port);
55 my($fk_column_name, $fk_table_name, %foreign_key);
56 my($pk_table_name, $primary_key_name);
57 my($singular_name, $source_port);
58
59 for my $table_name (sort keys %$info)
60 {
61 for my $item (@{$$info{$table_name}{foreign_keys} })
62 {
63 $pk_table_name = $$item{$temp_1};
64 $fk_table_name = $$item{$temp_2};
65 $fk_column_name = $$item{$temp_3};
66
67 if ($pk_table_name)
68 {
69 $singular_name = to_singular($pk_table_name);
70
71 if ($special_fk_column{$fk_column_name})
72 {
73 $primary_key_name = $special_fk_column{$fk_column_name};
74 }
75 elsif (defined($$info{$table_name}{columns}{$fk_column_name}) )
76 {
77 $primary_key_name = $fk_column_name;
78 }
79 elsif (defined($$info{$table_name}{columns}{id}) )
80 {
81 $primary_key_name = 'id';
82 }
83 else
84 {
85 die "Primary table '$pk_table_name'. Foreign table '$fk_table_name'. Unable to find primary key name for foreign key '$fk_column_name'\n"
86 }
87
88 $foreign_key{$fk_table_name} = {} if (! $foreign_key{$fk_table_name});
89 $foreign_key{$fk_table_name}{$fk_column_name} = {} if (! $foreign_key{$fk_table_name}{$fk_column_name});
90 $primary_key_name =~ s/${singular_name}_//;
91 $foreign_key{$fk_table_name}{$fk_column_name}{$table_name} = $primary_key_name;
92 }
93 }
94 }
95
96 my(@header) =
97 (
98 'Name',
99 'Type',
100 'Null',
101 'Key',
102 'Auto-increment',
103 );
104
105 my($table) = Text::Table::Manifold -> new
106 (
107 alignment =>
108 [
109 align_left,
110 align_left,
111 align_left,
112 align_left,
113 align_left,
114 ],
115 format => format_text_unicodebox_table,
116 headers => \@header,
117 join => "\n",
118 );
119 my(%type) =
120 (
121 'character varying' => 'varchar',
122 'int(11)' => 'integer',
123 '"timestamp"' => 'timestamp',
124 );
125
126 my($auto_increment);
127 my(@data);
128 my($index);
129 my($nullable);
130 my($primary_key);
131 my($type);
132
133 for my $table_name (sort keys %$info)
134 {
135 print "Table: $table_name.\n\n";
136
137 @data = ();
138 $index = undef;
139
140 for my $column_name (keys %{$$info{$table_name}{columns} })
141 {
142 $type = $$info{$table_name}{columns}{$column_name}{TYPE_NAME};
143 $type = $type{$type} ? $type{$type} : $type;
144 $nullable = $$info{$table_name}{columns}{$column_name}{IS_NULLABLE} eq 'NO';
145 $primary_key = $$info{$table_name}{primary_keys}{$column_name};
146 $auto_increment = $primary_key; # Database server-independent kludge :-(.
147
148 push @data,
149 [
150 $column_name,
151 $type,
152 $nullable ? 'not null' : '',
153 $primary_key ? 'primary key' : '',
154 $auto_increment ? 'auto_increment' : '',
155 ];
156
157 $index = pop @data if ($column_name eq 'id');
158 }
159
160 @data = sort{$$a[0] cmp $$b[0]} @data;
161
162 unshift @data, $index if ($index);
163
164 $table -> data(\@data);
165
166 print $table -> render_as_string, "\n\n";
167 }
168
169 If the environment vaiables DBI_DSN, DBI_USER and DBI_PASS are set (the
170 latter 2 are optional [e.g. for SQLite), then this demonstrates
171 extracting a lot of information from a database schema.
172
173 Also, for Postgres, you can set DBI_SCHEMA to a list of schemas, e.g.
174 when processing the MusicBrainz database.
175
176 For details, see
177 <http://blogs.perl.org/users/ron_savage/2013/03/graphviz2-and-the-dread-musicbrainz-db.html>.
178
179 See also xt/author/fk.t, xt/author/mysql.fk.pl and
180 xt/author/person.spouse.t.
181
183 "DBIx::Admin::TableInfo" is a pure Perl module.
184
185 It is a convenient wrapper around all of these DBI methods:
186
187 o table_info()
188 o column_info()
189 o primary_key_info()
190 o foreign_key_info()
191 o MySQL
192 Warning:
193
194 To get foreign key information in the output, the create table
195 statement has to:
196
197 o Include an index clause
198 o Include a foreign key clause
199 o Include an engine clause
200 As an example, a column definition for Postgres and SQLite,
201 which looks like:
202
203 site_id integer not null references sites(id),
204
205 has to, for MySql, look like:
206
207 site_id integer not null, index (site_id), foreign key (site_id) references sites(id),
208
209 Further, the create table statement, which for Postgres and
210 SQLite looks like:
211
212 create table designs (...)
213
214 has to, for MySql, look like:
215
216 create table designs (...) engine=innodb
217
218 o Oracle
219 See the "FAQ" for which tables are ignored under Oracle.
220
221 o Postgres
222 The latter now takes '%' as the value of the 'table' parameter to
223 new(), whereas older versions of DBD::Pg required 'table' to be set
224 to 'table'.
225
226 See the "FAQ" for which tables are ignored under Postgres.
227
228 o SQLite
229 See the "FAQ" for which tables are ignored under SQLite.
230
232 This module is available both as a Unix-style distro (*.tgz) and an
233 ActiveState-style distro (*.ppd). The latter is shipped in a *.zip
234 file.
235
236 See http://savage.net.au/Perl-modules.html for details.
237
238 See http://savage.net.au/Perl-modules/html/installing-a-module.html for
239 help on unpacking and installing each type of distro.
240
242 new(...) returns a "DBIx::Admin::TableInfo" object.
243
244 This is the class contructor.
245
246 Usage: DBIx::Admin::TableInfo -> new().
247
248 This method takes a set of parameters. Only the dbh parameter is
249 mandatory.
250
251 For each parameter you wish to use, call new as new(param_1 => value_1,
252 ...).
253
254 o catalog
255 This is the value passed in as the catalog parameter to
256 table_info() and column_info().
257
258 The default value is undef.
259
260 undef was chosen because it given the best results with MySQL.
261
262 Note: The MySQL driver DBD::mysql V 2.9002 has a bug in it, in that
263 it aborts if an empty string is used here, even though the DBI docs
264 say an empty string can be used for the catalog parameter to
265 "table_info()".
266
267 This parameter is optional.
268
269 o dbh
270 This is a database handle.
271
272 This parameter is mandatory.
273
274 o schema
275 This is the value passed in as the schema parameter to table_info()
276 and column_info().
277
278 The default value is undef.
279
280 Note: If you are using Oracle, call "new()" with schema set to uc
281 $user_name.
282
283 Note: If you are using Postgres, call "new()" with schema set to
284 'public'.
285
286 Note: If you are using SQLite, call "new()" with schema set to
287 'main'.
288
289 This parameter is optional.
290
291 o table
292 This is the value passed in as the table parameter to table_info().
293
294 The default value is '%'.
295
296 Note: If you are using an 'old' version of DBD::Pg, call "new()"
297 with table set to 'table'.
298
299 Sorry - I cannot tell you exactly what 'old' means. As stated
300 above, the default value (%) works fine with DBD::Pg V 2.17.1.
301
302 This parameter is optional.
303
304 o type
305 This is the value passed in as the type parameter to table_info().
306
307 The default value is 'TABLE'.
308
309 This parameter is optional.
310
312 columns($table_name, $by_position)
313 Returns an array ref of column names.
314
315 By default they are sorted by name.
316
317 However, if you pass in a true value for $by_position, they are sorted
318 by the column attribute ORDINAL_POSITION. This is Postgres-specific.
319
320 dbh2schema($dbh)
321 Warning: This is a function, not a method. It is called like this:
322
323 my($schema) = DBIx::Admin::TableInfo::dbh2schema($dbh);
324
325 The code is just:
326
327 my($dbh) = @_;
328 my($vendor) = uc $dbh -> get_info(17); # SQL_DBMS_NAME.
329 my(%schema) =
330 (
331 MYSQL => undef,
332 ORACLE => uc $$dbh{Username},
333 POSTGRESQL => 'public',
334 SQLITE => 'main',
335 );
336
337 return $schema{$vendor};
338
339 info()
340 Returns a hash ref of all available data.
341
342 The structure of this hash is described next:
343
344 o First level: The keys are the names of the tables
345 my($info) = $obj -> info();
346 my(@table_name) = sort keys %$info;
347
348 I use singular names for my arrays, hence @table_name rather than
349 @table_names.
350
351 o Second level: The keys are 'attributes', 'columns', 'foreign_keys'
352 and 'primary_keys'
353 my($table_attributes) = $$info{$table_name}{attributes};
354
355 This is a hash ref of the attributes of the table. The keys of
356 this hash ref are determined by the database server.
357
358 my($columns) = $$info{$table_name}{columns};
359
360 This is a hash ref of the columns of the table. The keys of this
361 hash ref are the names of the columns.
362
363 my($foreign_keys) = $$info{$table_name}{foreign_keys};
364
365 This is a hash ref of the foreign keys of the table. The keys of
366 this hash ref are the names of the tables which contain foreign
367 keys pointing to $table_name.
368
369 For MySQL, $foreign_keys will be the empty hash ref {}, as
370 explained above.
371
372 my($primary_keys) = $$info{$table_name}{primary_keys};
373
374 This is a hash ref of the primary keys of the table. The keys of
375 this hash ref are the names of the columns which make up the
376 primary key of $table_name.
377
378 For any database server, if there is more than 1 column in the
379 primary key, they will be numbered (ordered) according to the hash
380 key 'KEY_SEQ'.
381
382 For MySQL, if there is more than 1 column in the primary key, they
383 will be artificially numbered according to the order in which they
384 are returned by "column_info()", as explained above.
385
386 o Third level, after 'attributes': Table attributes
387 my($table_attributes) = $$info{$table_name}{attributes};
388
389 while ( ($name, $value) = each(%$table_attributes) )
390 {
391 Use...
392 }
393
394 For the attributes of the tables, there are no more levels in the
395 hash ref.
396
397 o Third level, after 'columns': The keys are the names of the columns.
398 my($columns) = $$info{$table_name}{columns};
399
400 my(@column_name) = sort keys %$columns;
401
402 o Fourth level: Column attributes
403 for $column_name (@column_name)
404 {
405 while ( ($name, $value) = each(%{$columns{$column_name} }) )
406 {
407 Use...
408 }
409 }
410
411 o Third level, after 'foreign_keys': An arrayref contains the details
412 (if any)
413 But beware slightly differing spellings depending on the database
414 server. This is documented in
415 <https://metacpan.org/pod/DBI#foreign_key_info>. Look closely at
416 the usage of the '_' character.
417
418 my($vendor) = uc $dbh -> get_info(17); # SQL_DBMS_NAME.
419
420 for $item (@{$$info{$table_name}{foreign_keys} })
421 {
422 # Get the name of the table pointed to.
423
424 $primary_table = ($vendor eq 'MYSQL') ? $$item{PKTABLE_NAME} : $$item{UK_TABLE_NAME};
425 }
426
427 o Third level, after 'primary_keys': The keys are the names of columns
428 These columns make up the primary key of the current table.
429
430 my($primary_keys) = $$info{$table_name}{primary_keys};
431
432 for $primary_key (sort{$$a{KEY_SEQ} <=> $$b{KEY_SEQ} } keys %$primary_keys)
433 {
434 $primary = $$primary_keys{$primary_key};
435
436 for $attribute (sort keys %$primary)
437 {
438 Use...
439 }
440 }
441
442 refresh()
443 Returns the same hash ref as info().
444
445 Use this after changing the database schema, when you want this module
446 to re-interrogate the database server.
447
448 tables()
449 Returns an array ref of table names.
450
451 They are sorted by name.
452
453 See the "FAQ" for which tables are ignored under which databases.
454
456 Here are tested parameter values for various database vendors:
457
458 o MS Access
459 my($admin) = DBIx::Admin::TableInfo -> new(dbh => $dbh);
460
461 In other words, the default values for catalog, schema, table and type will Just Work.
462
463 o MySQL
464 my($admin) = DBIx::Admin::TableInfo -> new(dbh => $dbh);
465
466 In other words, the default values for catalog, schema, table and type will Just Work.
467
468 o Oracle
469 my($dbh) = DBI -> connect($dsn, $username, $password);
470 my($admin) = DBIx::Admin::TableInfo -> new
471 (
472 dbh => $dbh,
473 schema => uc $username, # Yep, upper case.
474 );
475
476 See the FAQ for which tables are ignored under Oracle.
477
478 o PostgreSQL
479 my($admin) = DBIx::Admin::TableInfo -> new
480 (
481 dbh => $dbh,
482 schema => 'public',
483 );
484
485 For PostgreSQL, you probably want to ignore table names matching /^(pg_|sql_)/.
486
487 As stated above, for 'old' versions of DBD::Pg, use:
488
489 my($admin) = DBIx::Admin::TableInfo -> new
490 (
491 dbh => $dbh,
492 schema => 'public',
493 table => 'table', # Yep, lower case.
494 );
495
496 See the FAQ for which tables are ignored under Postgres.
497
498 o SQLite
499 my($admin) = DBIx::Admin::TableInfo -> new
500 (
501 dbh => $dbh,
502 schema => 'main',
503 );
504
505 In other words, the default values for catalog, table and type will Just Work.
506
507 See the FAQ for which tables are ignored under SQLite.
508
509 See the examples/ directory in the distro.
510
512 Which versions of the servers did you test?
513 Versions as at 2014-08-06:
514 +----------|-------------+
515 | Vendor | V |
516 +----------|-------------+
517 | MariaDB | 5.5.38 |
518 +----------|-------------+
519 | Oracle | 10.2.0.1.0 | (Not tested for years)
520 +----------|-------------+
521 | Postgres | 9.1.3 |
522 +----------|-------------+
523 | SQLite | 3.8.4.1 |
524 +----------|-------------+
525
526 But see these warnings
527 <https://metacpan.org/pod/DBIx::Admin::TableInfo#Description> when
528 using MySQL/MariaDB.
529
530 Which tables are ignored for which databases?
531 Here is the code which skips some tables:
532
533 next if ( ($vendor eq 'ORACLE') && ($table_name =~ /^BIN\$.+\$./) );
534 next if ( ($vendor eq 'POSTGRESQL') && ($table_name =~ /^(?:pg_|sql_)/) );
535 next if ( ($vendor eq 'SQLITE') && ($table_name eq 'sqlite_sequence') );
536
537 How do I identify foreign keys?
538 Note: The table names here come from xt/author/person.spouse.t.
539
540 See "FAQ" in DBIx::Admin::CreateTable for database server-specific
541 create statements to activate foreign keys.
542
543 Then try:
544
545 my($info) = DBIx::Admin::TableInfo -> new(dbh => $dbh) -> info;
546
547 print Data::Dumper::Concise::Dumper($$info{people}{foreign_keys}), "\n";
548
549 Output follows.
550
551 But beware slightly differing spellings depending on the database
552 server. This is documented in
553 <https://metacpan.org/pod/DBI#foreign_key_info>. Look closely at the
554 usage of the '_' character.
555
556 o MySQL
557 [
558 {
559 DEFERABILITY => undef,
560 DELETE_RULE => undef,
561 FKCOLUMN_NAME => "spouse_id",
562 FKTABLE_CAT => "def",
563 FKTABLE_NAME => "spouses",
564 FKTABLE_SCHEM => "testdb",
565 FK_NAME => "spouses_ibfk_2",
566 KEY_SEQ => 1,
567 PKCOLUMN_NAME => "id",
568 PKTABLE_CAT => undef,
569 PKTABLE_NAME => "people",
570 PKTABLE_SCHEM => "testdb",
571 PK_NAME => undef,
572 UNIQUE_OR_PRIMARY => undef,
573 UPDATE_RULE => undef
574 }
575 ]
576
577 Yes, there is just 1 element in this arrayref. MySQL can sliently
578 drop an index if another index can be used.
579
580 o Postgres
581 [
582 {
583 DEFERABILITY => 7,
584 DELETE_RULE => 3,
585 FK_COLUMN_NAME => "person_id",
586 FK_DATA_TYPE => "int4",
587 FK_NAME => "spouses_person_id_fkey",
588 FK_TABLE_CAT => undef,
589 FK_TABLE_NAME => "spouses",
590 FK_TABLE_SCHEM => "public",
591 ORDINAL_POSITION => 1,
592 UK_COLUMN_NAME => "id",
593 UK_DATA_TYPE => "int4",
594 UK_NAME => "people_pkey",
595 UK_TABLE_CAT => undef,
596 UK_TABLE_NAME => "people",
597 UK_TABLE_SCHEM => "public",
598 UNIQUE_OR_PRIMARY => "PRIMARY",
599 UPDATE_RULE => 3
600 },
601 {
602 DEFERABILITY => 7,
603 DELETE_RULE => 3,
604 FK_COLUMN_NAME => "spouse_id",
605 FK_DATA_TYPE => "int4",
606 FK_NAME => "spouses_spouse_id_fkey",
607 FK_TABLE_CAT => undef,
608 FK_TABLE_NAME => "spouses",
609 FK_TABLE_SCHEM => "public",
610 ORDINAL_POSITION => 1,
611 UK_COLUMN_NAME => "id",
612 UK_DATA_TYPE => "int4",
613 UK_NAME => "people_pkey",
614 UK_TABLE_CAT => undef,
615 UK_TABLE_NAME => "people",
616 UK_TABLE_SCHEM => "public",
617 UNIQUE_OR_PRIMARY => "PRIMARY",
618 UPDATE_RULE => 3
619 }
620 ]
621
622 o SQLite
623 [
624 {
625 DEFERABILITY => undef,
626 DELETE_RULE => 3,
627 FK_COLUMN_NAME => "spouse_id",
628 FK_DATA_TYPE => undef,
629 FK_NAME => undef,
630 FK_TABLE_CAT => undef,
631 FK_TABLE_NAME => "spouses",
632 FK_TABLE_SCHEM => undef,
633 ORDINAL_POSITION => 0,
634 UK_COLUMN_NAME => "id",
635 UK_DATA_TYPE => undef,
636 UK_NAME => undef,
637 UK_TABLE_CAT => undef,
638 UK_TABLE_NAME => "people",
639 UK_TABLE_SCHEM => undef,
640 UNIQUE_OR_PRIMARY => undef,
641 UPDATE_RULE => 3
642 },
643 {
644 DEFERABILITY => undef,
645 DELETE_RULE => 3,
646 FK_COLUMN_NAME => "person_id",
647 FK_DATA_TYPE => undef,
648 FK_NAME => undef,
649 FK_TABLE_CAT => undef,
650 FK_TABLE_NAME => "spouses",
651 FK_TABLE_SCHEM => undef,
652 ORDINAL_POSITION => 0,
653 UK_COLUMN_NAME => "id",
654 UK_DATA_TYPE => undef,
655 UK_NAME => undef,
656 UK_TABLE_CAT => undef,
657 UK_TABLE_NAME => "people",
658 UK_TABLE_SCHEM => undef,
659 UNIQUE_OR_PRIMARY => undef,
660 UPDATE_RULE => 3
661 }
662 ]
663
664 You can also play with xt/author/fk.t and xt/author/dsn.ini (especially
665 the 'active' option).
666
667 fk.t does not delete the tables as it exits. This is so
668 xt/author/mysql.fk.pl has something to play with.
669
670 See also xt/author/person.spouse.t.
671
672 Does DBIx::Admin::TableInfo work with SQLite databases?
673 Yes. As of V 2.08, this module uses the SQLite code "pragma
674 foreign_key_list($table_name)" to emulate the DBI call to
675 foreign_key_info(...).
676
677 What is returned by the SQLite "pragma foreign_key_list($table_name)" call?
678 An arrayref is returned. Indexes and their interpretations:
679
680 0: COUNT (0, 1, ...)
681 1: KEY_SEQ (0, or column # (1, 2, ...) within multi-column key)
682 2: PK_TABLE_NAME
683 3: FK_COLUMN_NAME
684 4: PK_COLUMN_NAME
685 5: UPDATE_RULE
686 6: DELETE_RULE
687 7: 'NONE' (Constant string)
688
689 As these are stored in an arrayref, I use $$row[$i] just below to refer
690 to the elements of the array.
691
692 How are these values mapped into the output?
693 See also the next point.
694
695 my(%referential_action) =
696 (
697 'CASCADE' => 0,
698 'RESTRICT' => 1,
699 'SET NULL' => 2,
700 'NO ACTION' => 3,
701 'SET DEFAULT' => 4,
702 );
703
704 The hashref returned for foreign keys contains these key-value pairs:
705
706 {
707 DEFERABILITY => undef,
708 DELETE_RULE => $referential_action{$$row[6]},
709 FK_COLUMN_NAME => $$row[3],
710 FK_DATA_TYPE => undef,
711 FK_NAME => undef,
712 FK_TABLE_CAT => undef,
713 FK_TABLE_NAME => $table_name,
714 FK_TABLE_SCHEM => undef,
715 ORDINAL_POSITION => $$row[1],
716 UK_COLUMN_NAME => $$row[4],
717 UK_DATA_TYPE => undef,
718 UK_NAME => undef,
719 UK_TABLE_CAT => undef,
720 UK_TABLE_NAME => $$row[2],
721 UK_TABLE_SCHEM => undef,
722 UNIQUE_OR_PRIMARY => undef,
723 UPDATE_RULE => $referential_action{$$row[5]},
724 }
725
726 This list of keys matches what is returned when processing a Postgres
727 database.
728
729 Have you got FK and PK backwards?
730 I certainly hope not. To me the FK_TABLE_NAME points to the
731 UK_TABLE_NAME.
732
733 The "pragma foreign_key_list($table_name)" call for SQLite returns data
734 from the create statement, and thus it reports what the given table
735 points to. The DBI call to foreign_key_info(...) returns data about
736 foreign keys referencing (pointing to) the given table. This can be
737 confusing.
738
739 Here is a method from the module App::Office::Contacts::Util::Create,
740 part of App::Office::Contacts.
741
742 sub create_organizations_table
743 {
744 my($self) = @_;
745 my($table_name) = 'organizations';
746 my($primary_key) = $self -> creator -> generate_primary_key_sql($table_name);
747 my($engine) = $self -> engine;
748 my($result) = $self -> creator -> create_table(<<SQL);
749 create table $table_name
750 (
751 id $primary_key,
752 visibility_id integer not null references visibilities(id),
753 communication_type_id integer not null references communication_types(id),
754 creator_id integer not null,
755 role_id integer not null references roles(id),
756 deleted integer not null,
757 facebook_tag varchar(255) not null,
758 homepage varchar(255) not null,
759 name varchar(255) not null,
760 timestamp timestamp not null default localtimestamp,
761 twitter_tag varchar(255) not null,
762 upper_name varchar(255) not null
763 ) $engine
764 SQL
765
766 $self -> dbh -> do("create index ${table_name}_upper_name on $table_name (upper_name)");
767
768 $self -> report($table_name, 'created', $result);
769
770 } # End of create_organizations_table.
771
772 Consider this line:
773
774 visibility_id integer not null references visibilities(id),
775
776 That means, for the 'visibilities' table, the info() method in the
777 current module will return a hashref like:
778
779 {
780 visibilities =>
781 {
782 ...
783 foreign_keys =>
784 {
785 ...
786 organizations =>
787 {
788 UK_COLUMN_NAME => 'id',
789 DEFERABILITY => undef,
790 ORDINAL_POSITION => 0,
791 FK_TABLE_CAT => undef,
792 UK_NAME => undef,
793 UK_DATA_TYPE => undef,
794 UNIQUE_OR_PRIMARY => undef,
795 UK_TABLE_SCHEM => undef,
796 UK_TABLE_CAT => undef,
797 FK_COLUMN_NAME => 'visibility_id',
798 FK_TABLE_NAME => 'organizations',
799 FK_TABLE_SCHEM => undef,
800 FK_DATA_TYPE => undef,
801 UK_TABLE_NAME => 'visibilities',
802 DELETE_RULE => 3,
803 FK_NAME => undef,
804 UPDATE_RULE => 3
805 },
806 },
807 }
808
809 This is saying that for the table 'visibilities', there is a foreign
810 key in the 'organizations' table. That foreign key is called
811 'visibility_id', and it points to the key called 'id' in the
812 'visibilities' table.
813
814 How do I use schemas in Postgres?
815 You may need to do something like this:
816
817 $dbh -> do("set search_path to $ENV{DBI_SCHEMA}") if ($ENV{DBI_SCHEMA});
818
819 $ENV{DBI_SCHEMA} can be a comma-separated list, as in:
820
821 $dbh -> do("set search_path to my_schema, public");
822
823 See DBD::Pg for details.
824
825 See Also
826 DBIx::Admin::CreateTable.
827
828 DBIx::Admin::DSNManager.
829
831 Version numbers < 1.00 represent development versions. From 1.00 up,
832 they are production versions.
833
835 <https://github.com/ronsavage/DBIx-Admin-TableInfo>
836
838 Log a bug on RT:
839 <https://rt.cpan.org/Public/Dist/Display.html?Name=DBIx-Admin-TableInfo>.
840
842 "DBIx::Admin::TableInfo" was written by Ron Savage <ron@savage.net.au>
843 in 2004.
844
845 Home page: http://savage.net.au/index.html
846
848 Australian copyright (c) 2004, Ron Savage.
849
850 All Programs of mine are 'OSI Certified Open Source Software';
851 you can redistribute them and/or modify them under the terms of
852 The Perl License, a copy of which is available at:
853 http://www.opensource.org/licenses/index.html
854
855
856
857perl v5.30.0 2019-07-26 DBIx::Admin::TableInfo(3)