1DBD::CSV(3)           User Contributed Perl Documentation          DBD::CSV(3)
2
3
4

NAME

6       DBD::CSV - DBI driver for CSV files
7

SYNOPSIS

9           use DBI;
10           # See "Creating database handle" below
11           $dbh = DBI->connect ("dbi:CSV:", undef, undef, {
12               f_ext      => ".csv/r",
13               RaiseError => 1,
14               }) or die "Cannot connect: $DBI::errstr";
15
16           # Simple statements
17           $dbh->do ("CREATE TABLE foo (id INTEGER, name CHAR (10))");
18
19           # Selecting
20           my $sth = $dbh->prepare ("select * from foo");
21           $sth->execute;
22           $sth->bind_columns (\my ($id, $name));
23           while ($sth->fetch) {
24               print "id: $id, name: $name\n";
25               }
26
27           # Updates
28           my $sth = $dbh->prepare ("UPDATE foo SET name = ? WHERE id = ?");
29           $sth->execute ("DBI rocks!", 1);
30           $sth->finish;
31
32           $dbh->disconnect;
33

DESCRIPTION

35       The DBD::CSV module is yet another driver for the DBI (Database
36       independent interface for Perl). This one is based on the SQL "engine"
37       SQL::Statement and the abstract DBI driver DBD::File and implements
38       access to so-called CSV files (Comma Separated Values). Such files are
39       often used for exporting MS Access and MS Excel data.
40
41       See DBI for details on DBI, SQL::Statement for details on
42       SQL::Statement and DBD::File for details on the base class DBD::File.
43
44   Prerequisites
45       The only system dependent feature that DBD::File uses, is the "flock
46       ()" function. Thus the module should run (in theory) on any system with
47       a working "flock ()", in particular on all Unix machines and on Windows
48       NT. Under Windows 95 and MacOS the use of "flock ()" is disabled, thus
49       the module should still be usable.
50
51       Unlike other DBI drivers, you don't need an external SQL engine or a
52       running server. All you need are the following Perl modules, available
53       from any CPAN mirror, for example
54
55         http://search.cpan.org/
56
57       DBI A recent version of the DBI (Database independent interface for
58           Perl).  See below why.
59
60       DBD::File
61           This is the base class for DBD::CSV, and it is part of the DBI
62           distribution. As DBD::CSV requires a matching version of DBD::File
63           which is (partly) developed by the same team that maintains
64           DBD::CSV. See META.json or Makefile.PL for the minimum versions.
65
66       SQL::Statement
67           A simple SQL engine. This module defines all of the SQL syntax for
68           DBD::CSV, new SQL support is added with each release so you should
69           look for updates to SQL::Statement regularly.
70
71           It is possible to run "DBD::CSV" without this module if you define
72           the environment variable $DBI_SQL_NANO to 1. This will reduce the
73           SQL support a lot though. See DBI::SQL::Nano for more details. Note
74           that the test suite does only test in this mode in the development
75           environment.
76
77       Text::CSV_XS
78           This module is used to read and write rows in a CSV file.
79
80   Installation
81       Installing this module (and the prerequisites from above) is quite
82       simple.  The simplest way is to install the bundle:
83
84           $ cpan Bundle::DBD::CSV
85
86       Alternatively, you can name them all
87
88           $ cpan Text::CSV_XS DBI DBD::CSV
89
90       or even trust "cpan" to resolve all dependencies for you:
91
92           $ cpan DBD::CSV
93
94       If you cannot, for whatever reason, use cpan, fetch all modules from
95       CPAN, and build with a sequence like:
96
97           gzip -d < DBD-CSV-0.40.tgz | tar xf -
98
99       (this is for Unix users, Windows users would prefer WinZip or something
100       similar) and then enter the following:
101
102           cd DBD-CSV-0.40
103           perl Makefile.PL
104           make test
105
106       If any tests fail, let us know. Otherwise go on with
107
108           make install UNINST=1
109
110       Note that you almost definitely need root or administrator permissions.
111       If you don't have them, read the ExtUtils::MakeMaker man page for
112       details on installing in your own directories. ExtUtils::MakeMaker.
113
114   Supported SQL Syntax
115       All SQL processing for DBD::CSV is done by SQL::Statement. See
116       SQL::Statement for more specific information about its feature set.
117       Features include joins, aliases, built-in and user-defined functions,
118       and more.  See SQL::Statement::Syntax for a description of the SQL
119       syntax supported in DBD::CSV.
120
121       Table- and column-names are case insensitive unless quoted. Column
122       names will be sanitized unless "raw_header" is true.
123

Using DBD::CSV with DBI

125       For most things, DBD-CSV operates the same as any DBI driver.  See DBI
126       for detailed usage.
127
128   Creating a database handle (connect)
129       Creating a database handle usually implies connecting to a database
130       server.  Thus this command reads
131
132           use DBI;
133           my $dbh = DBI->connect ("dbi:CSV:", "", "", {
134               f_dir => "/home/user/folder",
135               });
136
137       The directory tells the driver where it should create or open tables
138       (a.k.a.  files). It defaults to the current directory, so the following
139       are equivalent:
140
141           $dbh = DBI->connect ("dbi:CSV:");
142           $dbh = DBI->connect ("dbi:CSV:", undef, undef, { f_dir => "." });
143           $dbh = DBI->connect ("dbi:CSV:f_dir=.");
144
145       We were told, that VMS might - for whatever reason - require:
146
147           $dbh = DBI->connect ("dbi:CSV:f_dir=");
148
149       The preferred way of passing the arguments is by driver attributes:
150
151           # specify most possible flags via driver flags
152           $dbh = DBI->connect ("dbi:CSV:", undef, undef, {
153               f_schema         => undef,
154               f_dir            => "data",
155               f_dir_search     => [],
156               f_ext            => ".csv/r",
157               f_lock           => 2,
158               f_encoding       => "utf8",
159
160               csv_eol          => "\r\n",
161               csv_sep_char     => ",",
162               csv_quote_char   => '"',
163               csv_escape_char  => '"',
164               csv_class        => "Text::CSV_XS",
165               csv_null         => 1,
166               csv_bom          => 0,
167               csv_tables       => {
168                   syspwd => {
169                       sep_char    => ":",
170                       quote_char  => undef,
171                       escape_char => undef,
172                       file        => "/etc/passwd",
173                       col_names   => [qw( login password
174                                           uid gid realname
175                                           directory shell )],
176                       },
177                   },
178
179               RaiseError       => 1,
180               PrintError       => 1,
181               FetchHashKeyName => "NAME_lc",
182               }) or die $DBI::errstr;
183
184       but you may set these attributes in the DSN as well, separated by
185       semicolons.  Pay attention to the semi-colon for "csv_sep_char" (as
186       seen in many CSV exports from MS Excel) is being escaped in below
187       example, as is would otherwise be seen as attribute separator:
188
189           $dbh = DBI->connect (
190               "dbi:CSV:f_dir=$ENV{HOME}/csvdb;f_ext=.csv;f_lock=2;" .
191               "f_encoding=utf8;csv_eol=\n;csv_sep_char=\\;;" .
192               "csv_quote_char=\";csv_escape_char=\\;csv_class=Text::CSV_XS;" .
193               "csv_null=1") or die $DBI::errstr;
194
195       Using attributes in the DSN is easier to use when the DSN is derived
196       from an outside source (environment variable, database entry, or
197       configure file), whereas specifying entries in the attribute hash is
198       easier to read and to maintain.
199
200       The default value for "csv_binary" is 1 (True).
201
202       The default value for "csv_auto_diag" is <1>. Note that this might
203       cause trouble on perl versions older than 5.8.9, so up to and including
204       perl version 5.8.8 it might be required to use ";csv_auto_diag=0"
205       inside the "DSN" or "csv_auto_diag =" 0> inside the attributes.
206
207   Creating and dropping tables
208       You can create and drop tables with commands like the following:
209
210           $dbh->do ("CREATE TABLE $table (id INTEGER, name CHAR (64))");
211           $dbh->do ("DROP TABLE $table");
212
213       Note that currently only the column names will be stored and no other
214       data.  Thus all other information including column type (INTEGER or
215       CHAR (x), for example), column attributes (NOT NULL, PRIMARY KEY, ...)
216       will silently be discarded. This may change in a later release.
217
218       A drop just removes the file without any warning.
219
220       See DBI for more details.
221
222       Table names cannot be arbitrary, due to restrictions of the SQL syntax.
223       I recommend that table names are valid SQL identifiers: The first
224       character is alphabetic, followed by an arbitrary number of
225       alphanumeric characters. If you want to use other files, the file names
226       must start with "/", "./" or "../" and they must not contain white
227       space.
228
229   Inserting, fetching and modifying data
230       The following examples insert some data in a table and fetch it back:
231       First, an example where the column data is concatenated in the SQL
232       string:
233
234           $dbh->do ("INSERT INTO $table VALUES (1, ".
235                      $dbh->quote ("foobar") . ")");
236
237       Note the use of the quote method for escaping the word "foobar". Any
238       string must be escaped, even if it does not contain binary data.
239
240       Next, an example using parameters:
241
242           $dbh->do ("INSERT INTO $table VALUES (?, ?)", undef, 2,
243                     "It's a string!");
244
245       Note that you don't need to quote column data passed as parameters.
246       This version is particularly well designed for loops. Whenever
247       performance is an issue, I recommend using this method.
248
249       You might wonder about the "undef". Don't wonder, just take it as it
250       is. :-) It's an attribute argument that I have never used and will be
251       passed to the prepare method as the second argument.
252
253       To retrieve data, you can use the following:
254
255           my $query = "SELECT * FROM $table WHERE id > 1 ORDER BY id";
256           my $sth   = $dbh->prepare ($query);
257           $sth->execute ();
258           while (my $row = $sth->fetchrow_hashref) {
259               print "Found result row: id = ", $row->{id},
260                     ", name = ", $row->{name};
261               }
262           $sth->finish ();
263
264       Again, column binding works: The same example again.
265
266           my $sth = $dbh->prepare (qq;
267               SELECT * FROM $table WHERE id > 1 ORDER BY id;
268               ;);
269           $sth->execute;
270           my ($id, $name);
271           $sth->bind_columns (undef, \$id, \$name);
272           while ($sth->fetch) {
273               print "Found result row: id = $id, name = $name\n";
274               }
275           $sth->finish;
276
277       Of course you can even use input parameters. Here's the same example
278       for the third time:
279
280           my $sth = $dbh->prepare ("SELECT * FROM $table WHERE id = ?");
281           $sth->bind_columns (undef, \$id, \$name);
282           for (my $i = 1; $i <= 2; $i++) {
283               $sth->execute ($id);
284               if ($sth->fetch) {
285                   print "Found result row: id = $id, name = $name\n";
286                   }
287               $sth->finish;
288               }
289
290       See DBI for details on these methods. See SQL::Statement for details on
291       the WHERE clause.
292
293       Data rows are modified with the UPDATE statement:
294
295           $dbh->do ("UPDATE $table SET id = 3 WHERE id = 1");
296
297       Likewise you use the DELETE statement for removing rows:
298
299           $dbh->do ("DELETE FROM $table WHERE id > 1");
300
301   Error handling
302       In the above examples we have never cared about return codes. Of
303       course, this is not recommended. Instead we should have written (for
304       example):
305
306           my $sth = $dbh->prepare ("SELECT * FROM $table WHERE id = ?") or
307               die "prepare: " . $dbh->errstr ();
308           $sth->bind_columns (undef, \$id, \$name) or
309               die "bind_columns: " . $dbh->errstr ();
310           for (my $i = 1; $i <= 2; $i++) {
311               $sth->execute ($id) or
312                   die "execute: " . $dbh->errstr ();
313               $sth->fetch and
314                   print "Found result row: id = $id, name = $name\n";
315               }
316           $sth->finish ($id) or die "finish: " . $dbh->errstr ();
317
318       Obviously this is tedious. Fortunately we have DBI's RaiseError
319       attribute:
320
321           $dbh->{RaiseError} = 1;
322           $@ = "";
323           eval {
324               my $sth = $dbh->prepare ("SELECT * FROM $table WHERE id = ?");
325               $sth->bind_columns (undef, \$id, \$name);
326               for (my $i = 1; $i <= 2; $i++) {
327                   $sth->execute ($id);
328                   $sth->fetch and
329                       print "Found result row: id = $id, name = $name\n";
330                   }
331               $sth->finish ($id);
332               };
333           $@ and die "SQL database error: $@";
334
335       This is not only shorter, it even works when using DBI methods within
336       subroutines.
337

DBI database handle attributes

339   Metadata
340       The following attributes are handled by DBI itself and not by
341       DBD::File, thus they all work as expected:
342
343           Active
344           ActiveKids
345           CachedKids
346           CompatMode             (Not used)
347           InactiveDestroy
348           Kids
349           PrintError
350           RaiseError
351           Warn                   (Not used)
352
353       The following DBI attributes are handled by DBD::File:
354
355       AutoCommit
356           Always on
357
358       ChopBlanks
359           Works
360
361       NUM_OF_FIELDS
362           Valid after "$sth->execute"
363
364       NUM_OF_PARAMS
365           Valid after "$sth->prepare"
366
367       NAME
368       NAME_lc
369       NAME_uc
370           Valid after "$sth->execute"; undef for Non-Select statements.
371
372       NULLABLE
373           Not really working. Always returns an array ref of one's, as
374           DBD::CSV does not verify input data. Valid after "$sth->execute";
375           undef for non-Select statements.
376
377       These attributes and methods are not supported:
378
379           bind_param_inout
380           CursorName
381           LongReadLen
382           LongTruncOk
383

DBD-CSV specific database handle attributes

385       In addition to the DBI attributes, you can use the following dbh
386       attributes:
387
388   DBD::File attributes
389       f_dir
390           This attribute is used for setting the directory where CSV files
391           are opened. Usually you set it in the dbh and it defaults to the
392           current directory ("."). However, it may be overridden in statement
393           handles.
394
395       f_dir_search
396           This attribute optionally defines a list of extra directories to
397           search when opening existing tables. It should be an anonymous list
398           or an array reference listing all folders where tables could be
399           found.
400
401               my $dbh = DBI->connect ("dbi:CSV:", "", "", {
402                   f_dir        => "data",
403                   f_dir_search => [ "ref/data", "ref/old" ],
404                   f_ext        => ".csv/r",
405                   }) or die $DBI::errstr;
406
407       f_ext
408           This attribute is used for setting the file extension.
409
410       f_schema
411           This attribute allows you to set the database schema name. The
412           default is to use the owner of "f_dir". "undef" is allowed, but not
413           in the DSN part.
414
415               my $dbh = DBI->connect ("dbi:CSV:", "", "", {
416                   f_schema => undef,
417                   f_dir    => "data",
418                   f_ext    => ".csv/r",
419                   }) or die $DBI::errstr;
420
421       f_encoding
422           This attribute allows you to set the encoding of the data. With
423           CSV, it is not possible to set (and remember) the encoding on a
424           column basis, but DBD::File now allows the encoding to be set on
425           the underlying file. If this attribute is not set, or undef is
426           passed, the file will be seen as binary.
427
428       f_lock
429           With this attribute you can specify a locking mode to be used (if
430           locking is supported at all) for opening tables. By default, tables
431           are opened with a shared lock for reading, and with an exclusive
432           lock for writing. The supported modes are:
433
434           0 Force no locking at all.
435
436           1 Only shared locks will be used.
437
438           2 Only exclusive locks will be used.
439
440       But see "KNOWN BUGS" in DBD::File.
441
442   DBD::CSV specific attributes
443       csv_class
444           The attribute csv_class controls the CSV parsing engine. This
445           defaults to "Text::CSV_XS", but "Text::CSV" can be used in some
446           cases, too.  Please be aware that "Text::CSV" does not care about
447           any edge case as "Text::CSV_XS" does and that "Text::CSV" is
448           probably about 100 times slower than "Text::CSV_XS".
449
450   Text::CSV_XS specific attributes
451       csv_eol
452       csv_sep_char
453       csv_quote_char
454       csv_escape_char
455       csv_csv
456           The attributes csv_eol, csv_sep_char, csv_quote_char and
457           csv_escape_char are corresponding to the respective attributes of
458           the csv_class (usually Text::CSV_CS) object. You may want to set
459           these attributes if you have unusual CSV files like /etc/passwd or
460           MS Excel generated CSV files with a semicolon as separator.
461           Defaults are "\015\012"", ",", """ and """, respectively.
462
463           The csv_eol attribute defines the end-of-line pattern, which is
464           better known as a record separator pattern since it separates
465           records.  The default is windows-style end-of-lines "\015\012" for
466           output (writing) and unset for input (reading), so if on unix you
467           may want to set this to newline ("\n") like this:
468
469             $dbh->{csv_eol} = "\n";
470
471           It is also possible to use multi-character patterns as record
472           separators.  For example this file uses newlines as field
473           separators (sep_char) and the pattern "\n__ENDREC__\n" as the
474           record separators (eol):
475
476             name
477             city
478             __ENDREC__
479             joe
480             seattle
481             __ENDREC__
482             sue
483             portland
484             __ENDREC__
485
486           To handle this file, you'd do this:
487
488             $dbh->{eol}      = "\n__ENDREC__\n" ,
489             $dbh->{sep_char} = "\n"
490
491           The attributes are used to create an instance of the class
492           csv_class, by default Text::CSV_XS. Alternatively you may pass an
493           instance as csv_csv, the latter takes precedence. Note that the
494           binary attribute must be set to a true value in that case.
495
496           Additionally you may overwrite these attributes on a per-table base
497           in the csv_tables attribute.
498
499       csv_null
500           With this option set, all new statement handles will set
501           "always_quote" and "blank_is_undef" in the CSV parser and writer,
502           so it knows how to distinguish between the empty string and "undef"
503           or "NULL". You cannot reset it with a false value. You can pass it
504           to connect, or set it later:
505
506             $dbh = DBI->connect ("dbi:CSV:", "", "", { csv_null => 1 });
507
508             $dbh->{csv_null} = 1;
509
510       csv_bom
511           With this option set, the CSV parser will try to detect BOM (Byte
512           Order Mark) in the header line. This requires Text::CSV_XS version
513           1.22 or higher.
514
515             $dbh = DBI->connect ("dbi:CSV:", "", "", { csv_bom => 1 });
516
517             $dbh->{csv_bom} = 1;
518
519       csv_tables
520           This hash ref is used for storing table dependent metadata. For any
521           table it contains an element with the table name as key and another
522           hash ref with the following attributes:
523
524           o   All valid attributes to the CSV parsing module. Any of the can
525               optionally be prefixed with "csv_".
526
527           o   All attributes valid to DBD::File
528
529           If you pass it "f_file" or its alias "file", "f_ext" has no effect,
530           but "f_dir" and "f_encoding" still have.
531
532       csv_*
533           All other attributes that start with "csv_" and are not described
534           above will be passed to "Text::CSV_XS" (without the "csv_" prefix).
535           These extra options are only likely to be useful for reading
536           (select) handles. Examples:
537
538             $dbh->{csv_allow_whitespace}    = 1;
539             $dbh->{csv_allow_loose_quotes}  = 1;
540             $dbh->{csv_allow_loose_escapes} = 1;
541
542           See the "Text::CSV_XS" documentation for the full list and the
543           documentation.
544
545   Driver specific attributes
546       f_file
547           The name of the file used for the table; defaults to
548
549               "$dbh->{f_dir}/$table"
550
551       eol
552       sep_char
553       quote_char
554       escape_char
555       class
556       csv These correspond to the attributes csv_eol, csv_sep_char,
557           csv_quote_char, csv_escape_char, csv_class and csv_csv.  The
558           difference is that they work on a per-table basis.
559
560       col_names
561       skip_first_row
562           By default DBD::CSV assumes that column names are stored in the
563           first row of the CSV file and sanitizes them (see "raw_header"
564           below). If this is not the case, you can supply an array ref of
565           table names with the col_names attribute. In that case the
566           attribute skip_first_row will be set to FALSE.
567
568           If you supply an empty array ref, the driver will read the first
569           row for you, count the number of columns and create column names
570           like "col0", "col1", ...
571
572           Note that column names that match reserved SQL words will cause
573           unwanted and sometimes confusing errors. If your CSV has headers
574           that match reserved words, you will require these two attributes.
575
576           If "test.csv" looks like
577
578            select,from
579            1,2
580
581           the select query would result in "select select, from from test;",
582           which obviously is illegal SQL.
583
584       raw_header
585           Due to the SQL standard, field names cannot contain special
586           characters like a dot (".") or a space (" ") unless the column
587           names are quoted.  Following the approach of mdb_tools, all these
588           tokens are translated to an underscore ("_") when reading the first
589           line of the CSV file, so all field names are 'sanitized'. If you do
590           not want this to happen, set "raw_header" to a true value and the
591           entries in the first line of the CSV data will be used verbatim for
592           column headers and field names.  DBD::CSV cannot guarantee that any
593           part in the toolchain will work if field names have those
594           characters, and the chances are high that the SQL statements will
595           fail.
596
597           Currently, the sanitizing of headers is as simple as
598
599             s/\W/_/g;
600
601           Note that headers (column names) might be folded in other parts of
602           the code stack, specifically SQL::Statement, whose docs mention:
603
604            Wildcards are expanded to lower cased identifiers. This might
605            confuse some people, but it was easier to implement.
606
607           That means that in
608
609            my $sth = $dbh->prepare ("select * from foo");
610            $sth->execute;
611            while (my $row = $sth->fetchrow_hashref) {
612                say for keys %$row;
613                }
614
615           all keys will show as all lower case, regardless of the original
616           header.
617
618       It's strongly recommended to check the attributes supported by
619       "Metadata" in DBD::File.
620
621       Example: Suppose you want to use /etc/passwd as a CSV file. :-) There
622       simplest way is:
623
624           use DBI;
625           my $dbh = DBI->connect ("dbi:CSV:", undef, undef, {
626               f_dir           => "/etc",
627               csv_sep_char    => ":",
628               csv_quote_char  => undef,
629               csv_escape_char => undef,
630               });
631           $dbh->{csv_tables}{passwd} = {
632               col_names => [qw( login password uid gid realname
633                                 directory shell )];
634               };
635           $sth = $dbh->prepare ("SELECT * FROM passwd");
636
637       Another possibility where you leave all the defaults as they are and
638       override them on a per table basis:
639
640           require DBI;
641           my $dbh = DBI->connect ("dbi:CSV:");
642           $dbh->{csv_tables}{passwd} = {
643               eol         => "\n",
644               sep_char    => ":",
645               quote_char  => undef,
646               escape_char => undef,
647               f_file      => "/etc/passwd",
648               col_names   => [qw( login password uid gid
649                                   realname directory shell )],
650               };
651           $sth = $dbh->prepare ("SELECT * FROM passwd");
652
653   Driver private methods
654       These methods are inherited from DBD::File:
655
656       data_sources
657           The "data_sources" method returns a list of sub-directories of the
658           current directory in the form "dbi:CSV:directory=$dirname".
659
660           If you want to read the sub-directories of another directory, use
661
662               my $drh  = DBI->install_driver ("CSV");
663               my @list = $drh->data_sources (f_dir => "/usr/local/csv_data");
664
665       list_tables
666           This method returns a list of file-names inside $dbh->{directory}.
667           Example:
668
669               my $dbh  = DBI->connect ("dbi:CSV:directory=/usr/local/csv_data");
670               my @list = $dbh->func ("list_tables");
671
672           Note that the list includes all files contained in the directory,
673           even those that have non-valid table names, from the view of SQL.
674           See "Creating and dropping tables" above.
675

KNOWN ISSUES

677       ยท   The module is using flock () internally. However, this function is
678           not available on some platforms. Use of flock () is disabled on
679           MacOS and Windows 95: There's no locking at all (perhaps not so
680           important on these operating systems, as they are for single users
681           anyways).
682

TODO

684       Tests
685           Aim for a full 100% code coverage
686
687            - eol      Make tests for different record separators.
688            - csv_xs   Test with a variety of combinations for
689                       sep_char, quote_char, and escape_char testing
690            - quoting  $dbh->do ("drop table $_") for DBI-tables ();
691            - errors   Make sure that all documented exceptions are tested.
692                       . write to write-protected file
693                       . read from badly formatted csv
694                       . pass bad arguments to csv parser while fetching
695
696           Add tests that specifically test DBD::File functionality where that
697           is useful.
698
699       RT  Attack all open DBD::CSV bugs in RT
700
701       CPAN::Forum
702           Attack all items in http://www.cpanforum.com/dist/DBD-CSV
703
704       Documentation
705           Expand on error-handling, and document all possible errors.  Use
706           Text::CSV_XS::error_diag () wherever possible.
707
708       Debugging
709           Implement and document dbd_verbose.
710
711       Data dictionary
712           Investigate the possibility to store the data dictionary in a file
713           like .sys$columns that can store the field attributes (type, key,
714           nullable).
715
716       Examples
717           Make more real-life examples from the docs in examples/
718

SEE ALSO

720       DBI, Text::CSV_XS, SQL::Statement, DBI::SQL::Nano
721
722       For help on the use of DBD::CSV, see the DBI users mailing list:
723
724         http://lists.cpan.org/showlist.cgi?name=dbi-users
725
726       For general information on DBI see
727
728         http://dbi.perl.org/ and http://faq.dbi-support.com/
729

AUTHORS and MAINTAINERS

731       This module is currently maintained by
732
733           H.Merijn Brand <h.m.brand@xs4all.nl>
734
735       in close cooperation with and help from
736
737           Jens Rehsack <sno@NetBSD.org>
738
739       The original author is Jochen Wiedmann.  Previous maintainer was Jeff
740       Zucker
741
743       Copyright (C) 2009-2018 by H.Merijn Brand Copyright (C) 2004-2009 by
744       Jeff Zucker Copyright (C) 1998-2004 by Jochen Wiedmann
745
746       All rights reserved.
747
748       You may distribute this module under the terms of either the GNU
749       General Public License or the Artistic License, as specified in the
750       Perl README file.
751
752
753
754perl v5.30.0                      2019-07-26                       DBD::CSV(3)
Impressum