Hoi,
Ik heb een scriptje geschreven om heel veel jpg-plaatjes in een MySQL database te zetten, maar dit gaat niet helemaal goed. Ten eerste krijg ik bij sommige jpg'jes een mysql-foutmelding:
Daarnaast, bij de foto's waar ik geen foutmelding krijg, krijg ik een vaag plaatje als resultaat, zie: http://severjanin.nl/photos/1/tn_6.jpg
Kan iemand mij vertellen wat ik verkeerd doe?
Ik heb een scriptje geschreven om heel veel jpg-plaatjes in een MySQL database te zetten, maar dit gaat niet helemaal goed. Ten eerste krijg ik bij sommige jpg'jes een mysql-foutmelding:
code:
1
2
3
| DBD::mysql::db do failed: You have an error in your SQL syntax; check the manual that corresponds toDyour MySQL server version for the right syntax to use near 'Þ¾H¸³ Cã ÔÛç7$b¨¾VeA}Kh«AQSÚØtÁ¥GOÆõß|1ÊGV'' at line 2 at ./todb.pl line 45. |
Daarnaast, bij de foto's waar ik geen foutmelding krijg, krijg ik een vaag plaatje als resultaat, zie: http://severjanin.nl/photos/1/tn_6.jpg
Kan iemand mij vertellen wat ik verkeerd doe?
code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
| #!/usr/bin/perl -w
use strict;
use DBI;
use YAML qw(LoadFile);;
our $conf = LoadFile("../../config.yaml");
my $driver = 'mysql';
my $database = $conf->{mysql}{db};
my $host = $conf->{mysql}{host} || "localhost";
my $MySQLport = $conf->{mysql}{port} || '3306';
my $dsn = "DBI:$driver:database=$database;host=$host;port=$MySQLport";
our $dbh = DBI->connect($dsn, $conf->{mysql}{user}, $conf->{mysql}{pass});
$dbh->do("DROP TABLE fotos");
$dbh->do("create table fotos (album int, foto int, name varchar(150), description text, part int, file mediumblob, tn blob, primary key(album, foto))");
opendir(DIR, ".");
while (my $d = readdir(DIR)) {
next if ($d =~ /^\.\.?$/);
next if (!-d $d);
next if ($d =~ /\D/);
my $album = $d;
opendir(DIR2, "$album");
while (my $p = readdir(DIR2)) {
next if ($p =~ /^\.\.?$/);
next if ($p !~ /^(\d+)\.jpg/);
my $photo = $1;
print "$album/$photo.jpg\n";
open (FILE, "$album/$photo.jpg") || die $!;
my $file = "";
binmode FILE;
$file .= $_ while (<FILE>);
close FILE;
$file =~ s/"/\\"/g;
open (TN, "$album/tn_$photo.jpg") || die $!;
my $tn = "";
binmode TN;
$tn .= $_ while (<TN>);
close TN;
$tn =~ s/"/\\"/g;
$dbh->do("INSERT INTO fotos (album, foto, name, description, part, file, tn)
VALUES ($album, $photo, '', '', 0, \"$file\", \"$tn\")");
}
closedir(DIR2);
}
closedir(DIR); |