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

Warum Texterstellung mit künstlicher Intelligenz richtig gut ist
Warum Texterstellung mit künstlicher Intelligenz richtig gut istKünstliche Intelligenz ist dabei, die Welt zu erobern. Die größten Unternehmen entwickeln Systeme, die einen Text für Sie schreiben können. Und sie machen das sehr gut.

05.01.2022 | Berni

Vorteile eines flexiblen ERP Systems
Vorteile eines flexiblen ERP SystemsEin flexibles ERP System bietet in allen Unternehmensbereichen die Grundlage für eine erfolgreiche Verwaltung, Organisation und Planung aller Prozesse.

01.12.2021 | Berni


 

Aktuelle PHP Scripte

copycockpit

Lassen Sie eine KI in Sekundenschnelle hochwertige Texte für z.B. Blogs, Produkt-Beschreibungen und Landing-Pages schreiben.

17.01.2022 Berni | Kategorie: KI Tools
frase.io

Automatisch Texte von einer KI Schreiben lassen. Die Effizienz von Frase und die geschriebenen Texte machen es einfach, SEO-Texte zu schreiben.

27.12.2021 Berni | Kategorie: KI Tools
Marktplatz für Blog-Marketing und Blog-Vermarktung ansehen Marktplatz für Blog-Marketing und Blog-Vermarktung

Blogmission, hier finden Blogbetreiber (Publisher) und Firmen (Advertiser) einfach und effektiv zueinander.

20.12.2021 Berni | Kategorie: SEO/ DIENSTE
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 13:21 Uhr.