Hi Monks!
I am working on this code that allows users to upload pictures, to avoid page refreshes
And not to have the SQL INSERT duplicating the record I am trying to check if the pictures is already
in the database. I am kind of stuck here because of the value of “$flag_pic” been always set to one no matter what.
I know I am missing something or it is just lack of sleep.
As you can see I check if "@pics" is true first, the max numbers of pics in this array its only 4, but it can be 1 or 2 or 3 pics, its up to the user. As long as one of them
are in the database I don’t want allow the insert to happen again. I hope I made my self clear.
Here is the part of the code (sample) I am having this issue:
...
if(@pics)
{
my $dbh = SQLStuff->connect_mysql();
my $sth = $dbh->prepare("select * from test_users where user = ? "
+) or &justdie("Can't select from table: ",$dbh->errmsg);
$sth->execute($got_user_name);
#my (@pic1,@pic2,@pic3,@pic4,$flag_pic);
my $flag_pic;
while (my $row = $sth->fetchrow_hashref())
{
#push @pic1,$row->{image_name_1} || '';
#push @pic2,$row->{image_name_2} || '';
#push @pic3,$row->{image_name_3} || '';
#push @pic4,$row->{image_name_4} || '';
if(($row->{image_name_1} ne "") eq ($pics[0] ne "")){$flag_pic
+="1";}
if(($row->{image_name_2} ne "") eq ($pics[1] ne "")){$flag_pic
+="1";}
if(($row->{image_name_3} ne "") eq ($pics[2] ne "")){$flag_pic
+="1";}
if(($row->{image_name_4} ne "") eq ($pics[3] ne "")){$flag_pic
+="1";}
}
#my $check_pic1 = shift(@pic1);
#my $check_pic2 = shift(@pic2);
#my $check_pic3 = shift(@pic3);
#my $check_pic4 = shift(@pic4);
print "<br>751**$flag_pic**<br>";
# End check
if($flag_pic ne "1")
{
my $dbh = SQLStuff->connect_mysql();
my $sth = $dbh->prepare("insert into test_add(image_1,image_2,i
+mage_3,image_4,image_loc,user) values(?, ?, ?, ?, ?,?)")
or &justdie("Can't add data, please try again later! ",$dbh->e
+rrmsg);
$sth->execute((@pics, undef, undef, undef, undef)[0..3],$path_l
+oc[0],$got_user) or &justdie("Can't select from table: ",$dbh->errmsg
+);
}
}
...
Thanks for looking!