root/swish-e/branches/2.6/prog-bin/MySQL.pl

Revision 1106, 1.4 kB (checked in by augur, 6 years ago)

Changed the default perl hash bang to point at /usr/bin/perl.

  • Property svn:eol-style set to native
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
Line 
1 #!/usr/bin/perl -w
2 use strict;
3
4 =pod
5
6     This is an example program to index data stored in a MySQL database.
7
8     In this example, a table is read that contains "minutes" from some
9     organization's meetings.  The text of the minutes was stored in a
10     blob, compressed with zlib.
11
12     This script reads the record from MySQL, uncompresses the text, and
13     formats for swish-e.  The example below uses HTML, but you could
14     also format at XML, or even plain text.
15
16 =cut   
17
18
19 use DBI;
20 use Compress::Zlib;
21 use Time::Local;
22
23 my %database = {
24         dsn      => 'dbi:mysql:test',
25         user     => 'user',
26         password => 'pass',
27 };
28
29 my $dbh = DBI->connect( @database{qw/ dsn user password /}, { RaiseError => 1 } );
30
31 my $sth = $dbh->prepare("select id, date, minutes from meetings");
32
33 $sth->execute();
34
35 while ( my( $id, $date, $minutes) = $sth->fetchrow_array ) {
36
37     my $uncompressed = uncompress( $minutes );
38
39     my $unix_date = unixtime( $date );
40     
41
42     my $content = <<EOF;
43 <html>
44 <head>
45 <title>
46     Minutes for meeting on date $date
47 </title>
48 </head>
49 <body>
50 $uncompressed
51 </body>
52 </html>
53 EOF
54
55     my $length = length $content;
56
57     
58
59     print <<EOF;
60 Content-Length: $length
61 Last-Mtime: $unix_date
62 Path-Name: /minutes/index.cgi?id=$id
63 Document-Type: HTML
64
65 EOF
66     print $content;
67
68 }
69
70 sub unixtime {
71         my ( $y, $m, $d ) = split /-/, shift;
72         return timelocal(0,0,0,$d,$m-1,$y-1900);
73     };
74
75
Note: See TracBrowser for help on using the browser.