/[cvs]/nfo/perl/libs/libdb.pm
ViewVC logotype

Contents of /nfo/perl/libs/libdb.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.10 - (show annotations)
Tue Apr 8 23:07:57 2003 UTC (21 years, 9 months ago) by joko
Branch: MAIN
Changes since 1.9: +9 -70 lines
renamed core database helper functions
moved 'hash2Sql' and 'quotesql' to shortcuts::db

1 ## --------------------------------------------------------------------------------
2 ## $Id: libdb.pm,v 1.9 2003/02/09 04:47:58 joko Exp $
3 ## --------------------------------------------------------------------------------
4 ## $Log: libdb.pm,v $
5 ## Revision 1.9 2003/02/09 04:47:58 joko
6 ## + minor fix
7 ##
8 ## Revision 1.8 2002/12/12 02:48:58 joko
9 ## + played with fixing disconnectTarget
10 ##
11 ## Revision 1.7 2002/12/01 22:13:17 joko
12 ## + minor bugfix?
13 ##
14 ## Revision 1.6 2002/11/29 04:53:39 joko
15 ## + hash2Sql now knows about SQL_SELECT
16 ##
17 ## Revision 1.5 2002/11/17 07:18:38 joko
18 ## + small modification in hash2sql
19 ##
20 ## Revision 1.4 2002/10/16 22:36:42 joko
21 ## + sub testDbServer
22 ##
23 ## Revision 1.3 2002/07/27 00:28:20 cvsjoko
24 ## bugfixes
25 ##
26 ## Revision 1.2 2002/07/20 11:09:58 cvsjoko
27 ## + bugfixes
28 ## + dont' print sql-errors
29 ##
30 ## Revision 1.1 2002/07/19 18:14:03 cvsjoko
31 ## no message
32 ##
33 ##
34 ## --------------------------------------------------------------------------------
35
36 package libdb;
37
38 use strict;
39 use warnings;
40
41 require Exporter;
42 our @ISA = qw( Exporter );
43 our @EXPORT_OK = qw(
44 testDsn
45 connectTarget disconnectTarget sendSql
46 dbNow
47 dsn2dbname sqlDbAction createSqlDb dropSqlDb
48 testDsnForTables testDbServer
49 );
50
51
52 use Carp;
53 use DBI;
54 use Data::Dumper;
55
56 use shortcuts::db qw( dsn2dbname );
57
58 my $dbmeta_ref_cache;
59
60 sub testDsn {
61 my $dsn = shift;
62 my $result;
63 if ( my $dbh = DBI->connect($dsn, '', '', {
64 PrintError => 0,
65 } ) ) {
66 $dbh->disconnect();
67 return 1;
68 }
69 }
70
71 sub testDbServer {
72 my $dsn = shift;
73 $dsn =~ s/database=(\w+)//;
74
75 #print "testDbServer: $dsn", "\n";
76
77 my $result;
78 if ( my $dbh = DBI->connect($dsn, '', '', {
79 PrintError => 0,
80 } ) ) {
81 $dbh->disconnect();
82 return 1;
83 }
84 }
85
86
87
88 sub patch_dbmeta {
89
90 my $dbmeta = shift;
91
92 if ($dbmeta =~ m/^dbi:/) {
93 $dbmeta = {
94 dsn => $dbmeta,
95 trace_level => 0,
96 trace_file => undef,
97 };
98 }
99
100 return $dbmeta;
101
102 }
103
104 sub connectTarget {
105 my $dbmeta = shift;
106 croak "please supply a dsn or a \"dbmeta\"-hash" if (!$dbmeta);
107 $dbmeta = patch_dbmeta($dbmeta);
108 if (!$dbmeta->{connected}) {
109 if ($dbmeta->{dbh} = DBI->connect($dbmeta->{dsn}, '', '', { PrintError => 0 } )) {
110 $dbmeta->{dbh}->trace($dbmeta->{trace_level}, $dbmeta->{trace_file});
111 $dbmeta->{dbh}->{PrintError} = 0;
112 $dbmeta->{connected} = 1;
113 $dbmeta_ref_cache = $dbmeta;
114 return 1;
115 }
116 }
117 }
118
119 sub disconnectTarget {
120 #my $dbmeta = shift;
121 #print "disc\n";
122 #croak "please supply a \"dbmeta\"-hash" if (!$dbmeta);
123 #$dbmeta = patch_dbmeta($dbmeta);
124 #$dbmeta->{dbh} && $dbmeta->{dbh}->disconnect();
125 my $dbmeta = $dbmeta_ref_cache;
126 #print Dumper($dbmeta);
127 #$dbmeta->{dbh} && $dbmeta->{dbh}->disconnect();
128 $dbmeta->{dbh}->disconnect();
129 undef($dbmeta->{dbh});
130 undef($dbmeta);
131 undef($dbmeta_ref_cache);
132 }
133
134 sub sendSql {
135 my $sql = shift;
136 my $dbmeta_ref = shift;
137 if (!$dbmeta_ref) {
138 $dbmeta_ref = $dbmeta_ref_cache;
139 }
140 #print "sql: $sql", "\n";
141 if (!$dbmeta_ref->{connected}) {
142 print "not connected!", "\n";
143 return 0;
144 }
145 if (my $result = $dbmeta_ref->{dbh}->prepare($sql)) {
146 #if ($result->execute()) {
147 $result->execute();
148 return $result;
149 #}
150 }
151 }
152
153 sub dbNow {
154 #my $now_string = strftime "%a %b %e %H:%M:%S %Y", localtime;
155 my $now_string = strftime("%Y-%m-%d %H:%M:%S", localtime);
156 return $now_string;
157 }
158
159
160 sub sqlDbAction {
161 my $dsn = shift;
162 $dsn =~ s/database=.+?;//;
163 my $sql = shift;
164 my $dbmeta = {
165 dsn => $dsn,
166 trace_level => 1,
167 trace_file => 'dbitrace',
168 };
169 my $bool_ok;
170 if (connectTarget($dbmeta)) {
171 sendSql($sql);
172 #print "state: ", $dbmeta->{dbh}->state, "\n";
173 #print "err ", $dbmeta->{dbh}->err, "\n";
174 #$bool_ok = ($dbmeta->{dbh} && $dbmeta->{dbh}->state && !$dbmeta->{dbh}->err);
175 $bool_ok = ($dbmeta->{dbh} && !$dbmeta->{dbh}->err);
176 disconnectTarget($dbmeta);
177 }
178 return $bool_ok;
179 }
180
181 sub createSqlDb {
182 my $dsn = shift;
183 my $dbname = dsn2dbname($dsn);
184 print " - creating rdbms-database $dbname ($dsn) ...";
185 my $sql;
186 $sql = "CREATE DATABASE $dbname;";
187 if ( sqlDbAction($dsn, $sql) ) {
188 print "ok", "\n";
189 return 1;
190 } else {
191 print "failed", "\n";
192 return 0;
193 }
194 }
195
196 sub dropSqlDb {
197 my $dsn = shift;
198 my $dbname = dsn2dbname($dsn);
199 print " - dropping database $dbname", "\n";
200 my $sql;
201 $sql = "DROP DATABASE $dbname;";
202 sqlDbAction($dsn, $sql);
203 }
204
205 sub testDsnForTables {
206 my $dsn = shift;
207 connectTarget($dsn);
208 my $result = sendSql('SHOW TABLES;');
209 my $bool_tablesHere = $result->fetchrow_hashref();
210 $result->finish();
211 disconnectTarget($dsn);
212 return 1 if ($bool_tablesHere);
213 }
214
215 1;

MailToCvsAdmin">MailToCvsAdmin
ViewVC Help
Powered by ViewVC 1.1.26 RSS 2.0 feed