php.de

Zurück   php.de > Webentwicklung > PHP Einsteiger > PHP Tipps 2005

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 02.04.2005, 16:33  
Erfahrener Benutzer
 
Registriert seit: 11.03.2004
Beiträge: 138
Sonja
Standard Up-Date via Checkboxen

Hi

Habe mehrere Argumente, die können mit Checkboxen erfasst werden. Der Ersteintrag geht bestens.

PHP-Code:
<?php
<input type='checkbox' name='id_branche[]' value='$row[id_branche]'>

    foreach(
$_REQUEST['id_branche'] as $id_branche)
    {
    
$query3="insert into branche
    (id_pg,id_branche)values('$id_pg','$id_branche')"
;
    
$result3=mysql_query($query3);
    }
?>

Doch irgendwie ist der Knopf drin beim up-Date, In der Tabelle branche hat es pro angewählter Checkbox einen Eintrag. Doch beim Output kommt nur der erste Eintrag, und nicht alls Checkboxen die angewählt sein sollten sind es.

PHP-Code:
<?php//Branchen anzeigen    
$query4="SELECT * FROM bra order by name";
$result4=mysql_query($query4,$link);    
$i 0;
echo
" <table border='0' cellspacing='0' cellpadding='0'>";
while (
$row4 mysql_fetch_array($result4))

//Start Schleife
echo
<tr>
<td>
<input type='checkbox' name='id_branche[]' value='$row4[id_branche]'"
;

$query8="select * from branche
where id_pg='$row[id_pg]'"
;
$result8=mysql_query($query8);
$row8mysql_fetch_array ($result8);

if(
$row4[id_branche]=="$row8[id_branche]") echo "checked";
echo
"></td>
<td nowrap >$row4[name]</td>
</tr>
"
;
//nächste Zeile
$i++;  
//ende Schleife
}
echo
"</table>";
?>

Obwohl in der Tabelle branche 3 Einträge der id_pg sind, werden sie in der Auflistung nicht aktiviert.


Und dann gleich eine weitere Frage. In der Tabelle branche müssten bei einer Mutation Datensätze dazugefügt werden, und andere gelöscht. Wie kann ich das machen?

Danke

EDIT (Guradia): PHP-Tags
Sonja ist offline  
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 02.04.2005, 19:03  
Erfahrener Benutzer
 
Registriert seit: 21.05.2008
Beiträge: 2.150
Guradia befindet sich auf einem aufstrebenden Ast
Standard

http://de.php.net/mysql_error ... hat mit dem Problem weniger zu tun, aber wichtig ists ja doch


Dann sehr interesssant:
16.14. Warum soll ich nicht SELECT * schreiben?
http://www.php-faq.de/q/q-sql-select.html


Desweiteren wäre formatierterer Code auch lesbarer.


Performanter wäre das ganze noch mit einem LEFT JOIN, dass die branchen bereits im ersten Query mit einliest und die $query8 gleich weglässt
Guradia ist offline  
Alt 02.04.2005, 19:24  
Erfahrener Benutzer
 
Registriert seit: 11.03.2004
Beiträge: 138
Sonja
Standard

OK, ich habe select * gemacht, aber beide Tabellen haben nur die betroffenen Spalten, also jene die ich brauche.

Doch damit ist mein Problem nicht gelöst!

In der ersten Abfrage hole ich alle Branchen und in der zweiten Abfrage die Branchen des entsprechenden Produktes. Und beim Output sollten die Checkboxen der Branchen die das entsprechnde Produkt hat aktiviert sein.

Ich weiss, dass die richtig Anzahl Datensätze da wären, aber nur der erste zeigt sich!

Irgendwie liegt das Problem bei

if($row4[id_branche]=="$row8[id_branche]") {
echo 'checked="checked" ';
}


Danke für die Hilfe
Sonja ist offline  
Alt 02.04.2005, 20:54  
Erfahrener Benutzer
 
Registriert seit: 21.05.2008
Beiträge: 2.150
Guradia befindet sich auf einem aufstrebenden Ast
Standard

Wie wäre es, die Entscheidung von mysql_num_rows() abhängig zu machen?

Im Moment fragst du in $row8 auch schonmal NULL/false als Array ab, was ja deutlich falsch ist



btw: WIe sieht das Problem exakt aus?











Der Beitrag wurde verschoben, wegen...
... unzureichender Fragestellung.
... unzureichender Hintergrund-Informationen.
... Postings im falschen Forum.

Bemerkung:
Die gestellte Frage entspricht nicht dem Wissensstand eines/einer Fortgeschrittenen.

moved to PHP - Anfänger
Guradia ist offline  
Alt 02.04.2005, 22:05  
Erfahrener Benutzer
 
Registriert seit: 11.03.2004
Beiträge: 138
Sonja
Standard

gelöst

PHP-Code:
<?php
<input type='checkbox' name='id_branche[]' value='$row4[id_branche]'";

$id_pg=$row[id_pg];
$id_branche=$row4[id_branche];

$query8="
select id_pg,id_branche from pg_branche
where id_pg
='$id_pg'
and id_branche='$id_branche'";
$result8=mysql_query($query8);
$row8 = mysql_fetch_array($result8);

if($row8[id_branche]==$row4[id_branche]) 

echo "
checked";
}
?>
Danke allen für die Gedanken
Sonja ist offline  
 


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine 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
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
[Erledigt] Max Anzahl Checkboxen Hu5eL JavaScript, Ajax und mehr 2 25.06.2008 15:37
date in preg_replace Greezoo PHP-Fortgeschrittene 3 01.06.2008 16:41
Checkboxen und PHP errox PHP Tipps 2008 3 09.12.2007 21:23
Zustand der Checkboxen auslesen Pimbolie1979 PHP Tipps 2007 4 10.07.2007 20:39
Aktivieren einer Checkbox aktiviert viele andere Checkboxen buggybugga HTML, Usability und Barrierefreiheit 3 12.03.2007 16:23
Einfach Datepicker gesucht Cyberbob_at_tot PHP Tipps 2007 5 14.11.2005 09:10
checkboxen wizzardxx PHP Tipps 2005-2 7 16.10.2005 22:58
datum deutsch $date = date ("m.d.y"); PHP Tipps 2005-2 5 24.06.2005 14:41
(inhalte) der checkboxen aus mysql auslessen PHP Tipps 2005-2 4 07.06.2005 14:02
abfrage date // zeitraum hekto Datenbanken 14 13.03.2005 11:30
Problem mit auslesen von Checkboxen PHP Tipps 2005 2 08.03.2005 20:10
statt javascript new Date(); lieber mit php date PHP Tipps 2005 5 27.02.2005 16:55
Umfrage-Formular mit Checkboxen und MySQL PHP Tipps 2004-2 10 26.11.2004 18:20
$_POST und nicht geklickte Checkboxen PHP Tipps 2004 5 29.09.2004 21:41
Checkboxen value übergeben ?? PHP Tipps 2004 15 15.08.2004 23:17

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
javascript datum checkbox

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




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum

Creative Commons License
Dieser Inhalt ist unter einer Creative Commons-Lizenz lizenziert.