ebiz-webhosting
- Ad -
php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > PHP Developer Forum
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 

 


PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Post your PHP questions here!

Antwort
 
LinkBack Themen-Optionen Bewertung: Bewertung: 1 Stimmen, 1,00 durchschnittlich.
  #1 (permalink)  
Alt 14-04-2009, 16:41
Kiecker
 Registrierter Benutzer
Links : Onlinestatus : Kiecker ist offline
Registriert seit: Apr 2004
Beiträge: 22
Kiecker ist zur Zeit noch ein unbeschriebenes Blatt
Standard Doppelter Datenbankeintrag

Hallo Leute,
ich brauche mal Hilfe. Das Script unten includiere ich in ein Uploadscript. Ich möchte damit erreichen, dass jedes hochgeladenen Foto sofort in eine Datenbank eingetragen wird. In dieser Datenbank kann man dem Bild dann weitere Daten zurordnen. Leider wird jedes Bild dopplet eingetragen. Bilder die bereits zuvor in dem Verzeichnis vorhanden sind werden aber, wir gewünscht, übergangen. Wenn ich einen der doppelten Einträge lösche und das Script nocheinmal ausführe wird nicht erneut ein zweiter Eintrag erstellt.
Was muss ich ändern damit das Script ein neues Bild nur einmal einträgt bzw. warum tut es das jetzt zwei mal??


<?
$db = mysql_connect("xxxxx", "xxxxx", "xxxxx");
mysql_select_db("xxxxxx",$db);
$handle=opendir ('../images/kinder/');
while (false !== ($file = readdir ($handle)))
{
if ($file != '.')
if ($file != '..')
if ($file != 'thumbs')
if ($file != 'index.php')
if ($file != 'php.ini')
if ($file != 'upload.html')
if ($file != 'upload.php')
if ($file != 'dbeinlesen.php')


{
mysql_query($sql);
$sql ="SELECT * FROM `bereich1b` WHERE bild='$file'";
$result = mysql_query($sql);
if (mysql_num_rows($result) == 0)

{
$sql = "INSERT INTO bereich1b (bild) VALUES ('$file')";
mysql_query($sql);
echo "Bild <b>$file</b> wurde in die Datenbank <b>
<font color=\"green\">eingelesen</font></b><br>";
}
else
{
echo "Bild <b>$file</b> ist bereits in der Datenbank enthalten und wurde <b>
<font color=\"red\">nicht</font> erneut eingelesen</b><br>";
}

}

}

closedir($handle);
echo "<br><center><a href=\"../cms/index.php\">Zurück zum Adminbereich</a></center>";
?>

Geändert von Kiecker (15-04-2009 um 06:12 Uhr)
Mit Zitat antworten
  #2 (permalink)  
Alt 14-04-2009, 17:08
Benutzerbild von onemorenerd onemorenerd
  Moderator
Links : Onlinestatus : onemorenerd ist offline
Registriert seit: Mar 2005
Ort: Berlin
Beiträge: 9.481
onemorenerd wird schon bald berühmt werdenonemorenerd wird schon bald berühmt werden
Standard Re: Doppelter Datenbankeintrag

Ich rate, das Script zu löschen und es ganz neu zu schreiben.
Mit logischen Operatoren, statt dutzendfach verschachtelten If's.
Oder gleich mit glob() und Pattern für Bilddateien.
Mit einer einzigen DB-Abfrage, statt für jede Datei eine.
Ohne sinnlose Abfragen zwischendurch (dein jetziger Fehler!).
Mit ordentlich error_reporting.
Mit Zitat antworten
  #3 (permalink)  
Alt 15-04-2009, 06:13
Kiecker
 Registrierter Benutzer
Links : Onlinestatus : Kiecker ist offline
Registriert seit: Apr 2004
Beiträge: 22
Kiecker ist zur Zeit noch ein unbeschriebenes Blatt
Standard Hat sich erledigt

Hallo Leute,
die Sache hat sich erledigt.
Mit Zitat antworten
  #4 (permalink)  
Alt 15-04-2009, 07:27
asp2php
 Banned
Links : Onlinestatus : asp2php ist offline
Registriert seit: Feb 2004
Beiträge: 11.746
asp2php ist zur Zeit noch ein unbeschriebenes Blatt
Standard Re: Hat sich erledigt

Zitat:
Original geschrieben von Kiecker
Hallo Leute,
die Sache hat sich erledigt.
Wäre nett, wenn du die Lösung für die Nachwelt hierein posten würdest.
Mit Zitat antworten
  #5 (permalink)  
Alt 15-04-2009, 08:45
Kiecker
 Registrierter Benutzer
Links : Onlinestatus : Kiecker ist offline
Registriert seit: Apr 2004
Beiträge: 22
Kiecker ist zur Zeit noch ein unbeschriebenes Blatt
Standard Lösung

Zitat:
Wäre nett, wenn du die Lösung für die Nachwelt hierein posten würdest.
Das hatte ich mich nach der vernichtenden (und auch nicht gerade sehr hilfreichen Antwort) von onemorenerd gar nicht mehr getraut.

Die Lösung war einfach, es musste nur mysql_query($sql); gelöscht werden und schon funzte es.
__________________
@dd Internet Webservice
Rosenwinkel 22, 22607 Hamburg
Tel: 040 / 320 34 579 Mail:skieck@yahoo.com, Web: http://www.add-internet.de
Kursprogramm unter:
http://www.add-internet.de/kursunterlagen/Kursangebot.pdf

Mit Zitat antworten
  #6 (permalink)  
Alt 15-04-2009, 09:39
Peacie
 Registrierter Benutzer
Links : Onlinestatus : Peacie ist offline
Registriert seit: Nov 2003
Beiträge: 341
Peacie ist zur Zeit noch ein unbeschriebenes Blatt
Peacie eine Nachricht über ICQ schicken Peacie eine Nachricht über AIM schicken Peacie eine Nachricht über Yahoo! schicken
Standard

Zitat:
Das hatte ich mich nach der vernichtenden (und auch nicht gerade sehr hilfreichen Antwort) von onemorenerd gar nicht mehr getraut.
eine hilfreichere antwort gibts nicht...

das teil da funktioniert zwar nun, mehr aber auch nicht.
keine struktur, keine "vernünftige" kontrolle.

will meinen, die kontrolle was du in die datenbank einträgst sollte zum beispiel auswerten WAS eingetragen werden soll. und nicht das , was NICHT rein darf.
den dateinamen ungeprüft in die datenbank zu schreiben.. naja, ich hoffe du kontrollierst das bereits beim upload
__________________
Mibau Datendesign - Online Ferienwelt

Geändert von Peacie (15-04-2009 um 09:45 Uhr)
Mit Zitat antworten
  #7 (permalink)  
Alt 15-04-2009, 10:22
Benutzerbild von onemorenerd onemorenerd
  Moderator
Links : Onlinestatus : onemorenerd ist offline
Registriert seit: Mar 2005
Ort: Berlin
Beiträge: 9.481
onemorenerd wird schon bald berühmt werdenonemorenerd wird schon bald berühmt werden
Standard Re: Lösung

Zitat:
Original geschrieben von Kiecker
Das hatte ich mich nach der vernichtenden (und auch nicht gerade sehr hilfreichen Antwort) von onemorenerd gar nicht mehr getraut.
Vernichtend, weil dein Code leider wirklich nichts gutes an sich hat.
Zitat:
Die Lösung war einfach, es musste nur mysql_query($sql); gelöscht werden und schon funzte es.
Das meinte ich mit "sinnlose Abfragen zwischendurch (dein jetziger Fehler!)". Wie man sieht, hat dieser Hinweis auch ausgereicht. Du hast die Stelle dann selbst gefunden. Also war die Antwort doch hilfreich.
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an


PHP News

MariaDB 5.5 veröffentlicht
MariaDB 5.5 veröffentlichtDie freie MySQL-Alternative MariaDB wurde in der stabilen Version 5.5.23 veröffentlicht und soll einige Verbesserungen gegenüber Oracles Communityversion von MySQL mitbringen.

16.04.2012 | Berni

Deutsche Yii Framework Community
Deutsche Yii Framework CommunitySeit dem 19.03.2012 gibt es für die Yii PHP Framework Community ein deutsches Zuhause.

20.03.2012 | dhcomputer

 

Aktuelle PHP Scripte

Advanced Login ansehen Advanced Login

Login-System und Kundenverwaltung, die sich spielend leicht in bestehende Webseiten einbauen lässt und einen enormen Funktionsumfang bietet. Ihre eigene Webseite muss mit Advanced Login nicht umständlich an ein fertiges System angepasst werden.

25.05.2012 Madden | Kategorie: PHP/ Kundenverwaltung
BROM CMS/BelCal 3 ansehen BROM CMS/BelCal 3

Spezielles CMS für Betreiber von Ferienwohnungen. Komplette Seitenerstellung online, Verwaltung mehrerer Objekte, Reservierungssystem mit sofortigem Abgleich im Belegungskalender und vieles mehr bietet dieses Content Management System.

25.05.2012 belcal2 | Kategorie: PHP/ CMS
belbit LiveSupport Script ansehen belbit LiveSupport Script

Schnellen und unkomplizierten Support im LiveSupport-Chat anbieten. Ohne Datenbank und in wenigen Sekunden installiert.

24.05.2012 EichbaumMedia | Kategorie: PHP/ Chat
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 09:56 Uhr.