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! Fragen zu Laravel, YII oder anderen PHP-Frameworks.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 12-03-2007, 14:49
urishima
 Newbie
Links : Onlinestatus : urishima ist offline
Registriert seit: Mar 2007
Beiträge: 11
urishima ist zur Zeit noch ein unbeschriebenes Blatt
Standard [PHP] Update hat keinen Effekt

Guten Tag allerseits

Ich arbeite derzeit an einer Wissesdatenbank die komplett über den Browser per PHP gepflegt werden soll (Userverwaltung, Erstellen und ändern von Inhalten, etc...).
Nun bin ich gerade dabei das ändern von bereits bestehenden Beiträgen zu implementieren. Kern sind dabei 2 PHP-Dateien, die docchange.php und die docupd.inc.php
In der docchange.php werden Inhalte über einen WYSIWYG-Editor geändert (SPAW 2.0, falls das wichtig ist). Die docupd.inc.php übernimmt dabei das eigendliche Speichern per MYSQL - UPDATE.

Die docchange.php sieht folgendermaßen aus:
PHP-Code:
$query=mysql_query("SELECT titel, doc FROM doc WHERE doc_id = '".$_GET['id']."' ");
$erg=mysql_fetch_array($query); 
Das Skript bekommt hier aus eienr anderen Datei per URL die ID der betroffenen Einträge der Datenbank.

PHP-Code:
<form action="docupd.inc.php?id=<?echo $_GET['id'];?>" method="post">
<table borderln="0">
 <tr>
  <td>Titel:</td>
  <td><input type="text" name="titel" size="50"  value="<?echo $erg['titel'];?>" /></td>
 </tr><tr>
 <?

//Aufrufen der Editor-Funktion 
$spaw = new SpawEditor("spaw1"$erg['doc']);
$spaw->show();
}
?> 
 </tr>
</table>
<input type="submit" name="submit" value="Speichern" />
</form>
Hier wird der Editor eingefügt.

Der Titel des Documents wird extra in ein Textfeld eingegeben während das Dokument an sich im Editor eingegeben wird.

Die docupd.inc.php sieht folgendermaßen aus:
PHP-Code:
$sql "UPDATE doc SET titel = ".trim($_POST['titel']).", doc = ".trim($_POST['spaw1'])." WHERE doc_id = ".$_GET['id']." ";
$doc mysql_query($sql) or die (mysql_error());
header'Location: doclist.php' );
exit(); 
Auch hier wird die ID per URL übergeben und die geänderten Inhalte des Editors.
Ein
PHP-Code:
echo $_POST['titel'];
echo 
$_POST['doc']; 
gibt das richtige aus.

Ein
PHP-Code:
echo $doc
gibt nichts aus.

Zusammengefasst soll das Skript der ersten Datei die entsprechenden Einträge der Datenbank auslesen und zum ändern in die Felder schreiben (funktioniert) und das Skript der ersten Datei soll per Update die Datenentsprechend ändern (Funktioniert nicht).

Das Kuriose ist jetzt, dass in der Datenbank nicht nur nichts geändert wird.
Das mysql_error gibt mir nämliche Folgende Fehlermeldung:
Zitat:
Unknown column 'Halloasdfasdf' in 'field list'
(Der Originaleintrag lautet "Hallo" und zum testen des Skriptes hab ich einfach blind irgendwelche Buchstaben dahinter getippt).

Also versucht er nicht in die entsprechenden Spalten einzutragen, die im query stehen sondern versucht spalten zu finden, die genauso wie der geänderte Inhalt heißen. Das wiederum ist mir selbst unerklärlich (ja, man kann mich getrost noob nennen), dann wie gesagt sage ich ihm ja ind er query was er wohin schreiben soll. Da aich ihm auch die ID mitgebe kann es ja theoretisch keine verwechselungen der Einträge geben.

So, ich hoffe ich habe nichts an Informationen vergessen.

MFG
Uri
Mit Zitat antworten
  #2 (permalink)  
Alt 12-03-2007, 14:54
penizillin
 PHP Guru
Links : Onlinestatus : penizillin ist offline
Registriert seit: Feb 2004
Beiträge: 10.166
penizillin ist zur Zeit noch ein unbeschriebenes Blatt
Standard

spaltennamen werden in mysql in backticks gesetzt, strings - in hochkommata.
Mit Zitat antworten
  #3 (permalink)  
Alt 12-03-2007, 14:57
wahsaga
  Moderator
Links : Onlinestatus : wahsaga ist offline
Registriert seit: Sep 2001
Beiträge: 25.236
wahsaga befindet sich auf einem aufstrebenden Ast
Standard Re: [PHP] Update hat keinen Effekt

1. Regeln lesen, Code umbrechen.

Zitat:
Also versucht er nicht in die entsprechenden Spalten einzutragen, die im query stehen sondern versucht spalten zu finden, die genauso wie der geänderte Inhalt heißen.
"Er" macht nur das, was du ihm sagst.

Und dass es sich dabei nicht um Spaltennamen, sondern um Textliterale bzw. Strings handeln soll, hast du ihm nicht gesagt.
Also lies mal im Handbuch nach, wie man Strings in SQL-Queries kennzeichnet.
__________________
I don't believe in rebirth. Actually, I never did in my whole lives.
Mit Zitat antworten
  #4 (permalink)  
Alt 12-03-2007, 15:02
urishima
 Newbie
Links : Onlinestatus : urishima ist offline
Registriert seit: Mar 2007
Beiträge: 11
urishima ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Zitat:
Original geschrieben von penizillin
spaltennamen werden in mysql in backticks gesetzt, strings - in hochkommata.
Funktioniert
PHP-Code:
$sql "UPDATE doc SET `titel` = '".trim($_POST['titel'])."', `doc` = '".trim($_POST['spaw1'])."' WHERE `doc_id` = ".$_GET['id']." "
Ich hasse es wenn Lösungen so wiederlich einfach sind und ich einfach nicht darauf komme

Besten Dank, Penizilin ^^
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

Software für alle Arten von digitalen Marktplätzen
Software für alle Arten von digitalen MarktplätzenDigitale Marktplätze sind nicht nur im B2C Geschäft seit Jahren etabliert, sondern erfreuen sich mit Kleinanzeigen-Märkten auf lokaler und regionaler Ebene auch im privaten Bereich wachsender Beliebtheit.

09.11.2021 | Berni

Von 0 auf über 2 Mio € Umsatz in weniger als 12 Monaten – wie die Pixelwerker das nur durch SEO geschafft haben
Von 0 auf über 2 Mio € Umsatz in weniger als 12 Monaten – wie die Pixelwerker das nur durch SEO geschafft habenSEO oder SEA? Warum SEO die besserer Methode ist.

01.10.2021 | Berni


 

Aktuelle PHP Scripte

ebiz-trader 6.0 - Das professionelle PHP Marktplatz Script ansehen ebiz-trader 6.0 - Das professionelle PHP Marktplatz Script

Mit unserer Lösungen können Sie nahezu jeden B2B / B2C Marktplatz betreiben den Sie sich vorstellen können. Ganz egal ob Sie einen Automarktplatz, Immobilenportal oder einfach einen Anzeigenmarkt betreiben möchten. Mit ebiz-trader können Sie Ihre Anforder

09.11.2021 Berni | Kategorie: PHP/ Anzeigenmarkt
PHP Newsletter Script SuperWebMailer ansehen PHP Newsletter Script SuperWebMailer

Die webbasierte PHP Newsletter Software SuperWebMailer ist die optimale Lösung zur Durchführung eines erfolgreichen E-Mail-Marketings. Zur Nutzung des PHP Script-Pakets ist eine eigene Webpräsenz/Server mit PHP 5 oder neuer, MySQL 4 oder neuer und die

28.10.2021 mirko_swm | Kategorie: PHP/ Mail
Guestbook Light ansehen Guestbook Light

Das Guestbook Light (kurz: "Gblight") ist ein kinderleichtes Gästebuch in PHP. Durch den Einsatz einer SQLite Datenbank ist es einfach, leicht portabel und schnell. Aufgrund moderner Techniken erfüllt Gblight auch die neuesten Webstandards.

28.10.2021 scripthostingnet | Kategorie: PHP/ Gaestebuch
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 20:10 Uhr.