jeeroy
Goto Top

PHP Erkennt einen Falschen Index, nur wieso?

Hallo Leute,
in meinem Code, sollen Werte einem Array zugewiesen werden, jedoch wird dabei ein Falscher Index erkannt.

Mein Code lautetet:

<?php
    /* Pkey = Primarkey */
    $pkey = "SERIEN_NR";  
    $pkey[1] = "COMPUTERNAME";  
    $pkey[2] = "INVENTARNUMMER";  
    $res_wcms = mysql_query("SELECT * FROM `computername`");  
    
    
    for($x=0; $x < count($pkey); $x++){
        
        $i = 0;
        $l = 0;
        while($dsatz_wcms = mysql_fetch_assoc($res_wcms)){
            /* Speichert alle Seriennummern im $pkey[$x] aufwärts zählend [$i] */
            $pkey[$x][$i] = $dsatz_wcms[$pkey[$x]];
            $i++;
         }
}
?>
In der Zeile 25 meckert er mit folgender Meldung: ---> $pkey[$x][$i] = $dsatz_wcms[$pkey[$x]];
Notice: Undefined index: GERIEN_NR in /home/wcms/backend/scripts/be_sts_doppelte_pk.php on line 25 Notice: Undefined index: G in /home/wcms/backend/scripts/be_sts_doppelte_pk.php on line 25 Notice: Undefined index: G in /home/wcms/backend/scripts/be_sts_doppelte_pk.php on line 25

Wie man sieht macht er aus dem Index $pkey[$x] = GERIEN_NR obwohl das ja SERIEN_NR lauten soll.
Das G zieht er sich wohl aus der ersten Seriennummer, die eingelesen wird, ich weiss nur nicht, warum er das da reinsetzt.

Könnt ihr mir vielleicht helfen?
Danke!

Content-Key: 174519

Url: https://administrator.de/contentid/174519

Printed on: April 25, 2024 at 01:04 o'clock

Member: godlie
godlie Oct 12, 2011 at 07:45:10 (UTC)
Goto Top
Hallo,

nachdem meine Glaskugel grad in der Reperatur ist tu ich mir schwer zu erkennen wo deine Probleme liegen.

Wie wäre es denn wenn du uns mal erzählst wie die Tabelle computername aufgebaut ist?

Ich glaube du hast das Konzept vom auslesen der Datensätze aus einer Datenbank nicht ganz verstanden, du kannst die Spalten die du haben möchtest
auch im Query angeben, was man auch machen sollte denn ein SELECT * ist böse.

Die Konstruktion aus for und while kannst knicken, es reicht eine reine while schleife.
Member: Jeeroy
Jeeroy Oct 12, 2011 at 08:23:09 (UTC)
Goto Top
Hey Godlie,

die Tabelle Computername ist mit einer Spalte für ID besetzt (Auto_incroment), einer Spalte COMPUTERNAME (var_char8), SERIEN_NR(var_char12) und INVENTARNUMMER(var_char12).

den Code habe ich nun auf:
<?php
    /* Pkey = Primarkey */
    $pkey = "SERIEN_NR";  
    $pkey[1] = "COMPUTERNAME";  
    $pkey[2] = "INVENTARNUMMER";  
    
    
    
    for($x=0; $x < count($pkey); $x++){
        
        $i = 0;
        $l = 0;
        $res_wcms = mysql_query("SELECT ".$pkey[$x]." FROM `computername`");  
        while($dsatz_wcms = mysql_fetch_assoc($res_wcms)){
            /* Speichert alle Seriennummern im $pkey[$x] aufwärts zählend [$i] */
            $pkey[$x][$i] = $dsatz_wcms[$pkey[$x]];
            $i++;
         }
}

geändert.
Wie ich die for und while schleife zu einer while machen soll, weiss ich nicht, wie du das meinst, dass es immernoch den gleichen effekt hat.

PS: Wieso ist es Böse, wenn man es mit SELECT * macht?
Member: godlie
godlie Oct 12, 2011 at 08:42:31 (UTC)
Goto Top
Hallo,

Warum machst du das mit den PKEYS ? das ist komplett für die Katz.

Probier mal diesen CODE aus und schau was als Ergebnis dabei rauskommt:

<?php
echo '<pre>';  
$qry = mysql_query("SELECT `SERIEN_NR`,`COMPUTERNAME`,`INVENTARNUMMER` FROM `computername`") or die(mysql_error());  
while($res = mysql_fetch_assoc($qry))
{
  var_dump($res);
}
echo '</pre>';  
?>
Was willst du eigentlich erreichen ? Wie soll das Array zum Schluss aussehen?
Member: Jeeroy
Jeeroy Oct 12, 2011 at 08:59:35 (UTC)
Goto Top
Ich habe das so gemacht, weil das die für mich ersichtliche Lösung für mein Problem war, weil ich noch nicht so lange programmiere.
Erreichen wollte ich damit letztendlich, dass ich gucken kann ob irgendein Computername oder eine Seriennummer oder eine Inventarnummer doppelt vergeben ist und wenn ja wollte ich die asugegeben haben.
Mein Code geht so weiter...

<?php
    /* Pkey = Primarkey */
    $pkey = "SERIEN_NR";  
    $pkey[1] = "COMPUTERNAME";  
    $pkey[2] = "INVENTARNUMMER";  
    
    
    
    for($x=0; $x < count($pkey); $x++){
        
        $i = 0;
        $l = 0;
        $res_wcms = mysql_query("SELECT ".$pkey[$x]." FROM `computername`");  
        while($dsatz_wcms = mysql_fetch_assoc($res_wcms)){
            /* Speichert alle Seriennummern im $pkey[$x] aufwärts zählend [$i] */
            $pkey[$x][$i] = $dsatz_wcms[$pkey][$x];
            $i++;
	}
        $count = array_count_values($pkey[$x]);
        while(list($pkey_erg, $menge) = each ($count)){
            if($menge > 1){
                $pkey_erg[$l] = $pkey_erg;
                $l++;
            }
        }
        
        if($l >= 1){
            echo "<div id=info class=info>";  
                echo "<b>Warnung!</b><br>";  
                echo "Folgende/r ".$pkey[$x]." ist mehrfach vergeben:<br>";  
                for($s=0; $s < $l; $s++){
                    echo "<li>".$pkey_erg[$s]."</li><br>";  
                }
            echo "</div>";  
        }
        
    }
?>
Member: godlie
godlie Oct 12, 2011 at 09:20:58 (UTC)
Goto Top
Hm ...

Eine wesentlich einfache variante:

$qry = array();
//doppelte serien_nr
$qry['Sn'] = "SELECT ID,SERIEN_NR,COMPUTERNAME,INVENTARNUMMER FROM computername GROUP BY SERIEN_NR HAVING ( COUNT(SERIEN_NR) > 1 )";  
//doppelte comName
$qry['Cn'] = "SELECT ID,SERIEN_NR,COMPUTERNAME,INVENTARNUMMER FROM computername GROUP BY COMUPTERNAME HAVING ( COUNT(COMPUTERNAME) > 1 )";  
//doppelte inventar
$qry['In'] = "SELECT ID,SERIEN_NR,COMPUTERNAME,INVENTARNUMMER FROM computername GROUP BY INVENTARNUMMER HAVING ( COUNT(INVENTARNUMMER) > 1 )";  

//auswertungen
$data = array();
foreach($qry as $key => $value)
{
  while($res = mysql_fetch_assoc($value)) {
    $data[$key] = $res;
  }
}

//ausgabe
foreach($data as $key => $value) {
  echo $key;
  if(count($value) > 0) {
    foreach($value as $singleValue) {
        var_dump($singleValue);
    } else {
    echo "nothing found";  
    }
  }
}
?>
Member: Jeeroy
Jeeroy Oct 12, 2011 at 09:56:02 (UTC)
Goto Top
Hey,
du hast mir mit dem Befehl:
$qry['Cn'] = "SELECT ID,SERIEN_NR,COMPUTERNAME,INVENTARNUMMER FROM computername GROUP BY COMUPTERNAME HAVING ( COUNT(COMPUTERNAME) > 1 )";  
sehr weitergeholfen.

Ich habe daraus nun das gebastelt:
<?php
    /* Pkey = Primarkey */
    $pkey = "SERIEN_NR";  
    $pkey[1] = "COMPUTERNAME";  
    $pkey[2] = "INVENTARNUMMER";  
    
    
    
    for($x=0; $x < count($pkey); $x++){
        
        $res_wcms = mysql_query("SELECT ".$pkey[$x]." FROM computername GROUP BY ".$pkey[$x]." HAVING ( COUNT(".$pkey[$x].") > 1 )");  
        $num_wcms = mysql_num_rows($res_wcms);
        
        if($num_wcms >= 1){
            echo "<div id=info class=info>";  
                echo "<b>Warnung!</b><br>";  
                echo "Folgende/r ".$pkey[$x]." ist mehrfach vergeben:<br>";  
                while($dsatz_wcms = mysql_fetch_assoc($res_wcms)){
                    echo "<li>".$dsatz_wcms[$pkey[$x]]."</li><br>";  
                }
            echo "</div>";  
        }
    }
?>
Und das funtkioniert, wollte es halt so haben, dass ich jederzeit einen weiteren $pkey hinzufügen kann...

Danke für deine Hilfe!