Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

Multiarray aus einem Mysql Resultset erstellen

Frage Entwicklung PHP

Mitglied: moK

moK (Level 1) - Jetzt verbinden

16.05.2011, aktualisiert 07:13 Uhr, 3289 Aufrufe, 3 Kommentare

Hi Leute,

stellt euch vor ihr habt ein resultset von mysql das ungefähr so aussieht (und ihr könnt diesen nicht ändern):

Hardware Fehlerart PC-NR Fehler Zusatzinformation PC Zusatzinformation
Soundkartekein ton213irgendwasschwarzes gehäuse
GPUkein bild213irgendwasschwarzes gehäuse
GPUkomisches geräusch213irgendwasschwarzes gehäuse
GPUkomisches geräusch213irgendwasschwarzes gehäuse
GPUkomisches geräusch231irgendwasrotes gehäuse

ich würde daruas gerne eine tabelle generieren die so ungefähr aussieht, das array sollte dann theoretisch genau so aussehen...

soundkarte
->kein ton
-->213 - irgendwas - schwarzes gehäuse 1x
gpu
->kein bild
-->213 - irgendwas - schwarzes gehäuse 1x
-> komisches geräusch
-->213 - irgendwas - schwarzes gehäuse 2x
-->231 - irgendwas - rotes gehäuse 1x


die anzahl der doppelten fehler müsste irgendwie berechnet werden... auf jedenfall bin ich am verzweifeln. Mein Kopf lässt mich nicht mal dazu kommen eine vernünftig überlegte Zeile zu schreiben. Könnt ihr mir helfen daraus ein gescheites Array zu basteln?

Gruß moK

EDIT:

so bin ungleiblicherweise auf eine 99%ige Lösung gekommen:


01.
$first = TRUE; 
02.
while ($row = mysqli_fetch_row($result)) { 
03.
	 
04.
	if($first) { 
05.
	 $temp_fehlerart = $row[1];  
06.
	 $temp_hardware = $row[0]; 
07.
	 $first = FALSE; 
08.
09.
	 
10.
	if($temp_fehlerart != $row[1]) { 
11.
		$pcliste_array = NULL; 
12.
		$temp_fehlerart = $row[1]; 
13.
14.
	 
15.
	if($temp_hardware != $row[0]) { 
16.
		$pcliste_array = NULL; 
17.
		$fehlerartliste_array = NULL; 
18.
		$temp_hardware = $row[0]; 
19.
20.
	 
21.
		 
22.
	$pcliste_array[] = $row[2] . ';' . $row[3] . ';' . $row[4];   
23.
	 
24.
	$fehlerartliste_array[$row[1]] = $pcliste_array
25.
	 
26.
	$hardwareliste_array[$row[0]] = $fehlerartliste_array
27.
	 
28.
}
jedoch fehlt mir immer noch die anztahl der doppelten oder mehrfachen fehler...
Mitglied: dog
16.05.2011 um 10:10 Uhr
öhm?
01.
SELECT *,COUNT(*) FROM tbl1 GROUP BY Hardware,Fehlerart,PC-NR,Fehler-Zusatzinformationen,"PC Zusatzinformationen"
Bitte warten ..
Mitglied: moK
16.05.2011 um 10:30 Uhr
ich weiß.. leider kann ich es so aber nicht lösen... gehen wir davon aus das der select unantastbar ist und man sowas mit php lösen muss...
Bitte warten ..
Mitglied: dog
16.05.2011 um 19:40 Uhr
Und, ist doch genauso leicht...

01.
 
02.
<?php 
03.
 
04.
	error_reporting(E_ALL|E_STRICT); 
05.
	ini_set('display_errors','On'); 
06.
 
07.
	$sql = "SELECT * FROM tbl"
08.
	 
09.
	$q = mysql_query($sql); 
10.
	 
11.
	$data = array(); 
12.
	 
13.
	while ($row = mysql_fetch_assoc($q)) { 
14.
		$path = &$data[$row['Hardware']][$row['Fehlerart']][$row['PC-NR']][$row['Fehler-Zusatzinformationen']][$row['PC Zusatzinformationen']]; 
15.
		if($path == null) 
16.
			$path = 0; 
17.
			 
18.
		$path++;	 
19.
20.
 
21.
	var_dump($data); 
22.
 
23.
?>
Bitte warten ..
Ähnliche Inhalte
Neue Wissensbeiträge
Google Android

Cyanogenmod alternative Downloadquelle

(5)

Tipp von Lochkartenstanzer zum Thema Google Android ...

Batch & Shell

Batch als Dienst bei Systemstart ohne Anmeldung ausführen

(5)

Tipp von tralveller zum Thema Batch & Shell ...

Sicherheits-Tools

Sicherheitstest von Passwörtern für ganze DB-Tabellen

(1)

Tipp von gdconsult zum Thema Sicherheits-Tools ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
gelöst Statische Routen mit Shorewall, ISC-DHCP Server konfigurieren für Android Devices (25)

Frage von terminator zum Thema LAN, WAN, Wireless ...

Server
gelöst Wie erkennen, dass nur deutsche IPs Zugang zu einer Website haben? (22)

Frage von Coreknabe zum Thema Server ...

Hardware
16-20 Port POE Switch mit VLAN (19)

Frage von thomasreischer zum Thema Hardware ...

Windows Server
Exchange HyperV Prozessorlast (18)

Frage von theoberlin zum Thema Windows Server ...