[GastForen Programmierung/Entwicklung PHP und MySQL doppelte ausgaben unterdrücken (LEFT JOIN+ON)

  • Suche
  • Hilfe
  • Lesezeichen
  • Benutzerliste
Themen
Beiträge
Moderatoren
Letzter Beitrag

doppelte ausgaben unterdrücken (LEFT JOIN+ON)

macmac
Beiträge gesamt: 394

17. Mai 2007, 15:13
Beitrag # 1 von 6
Bewertung:
(2335 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
hi zusammen

nach nächtelangem probieren und vielen frustmomenten habe ich fast mein bescheidenes ziel erreicht. nun fehlt der letzte etappensieg. diesen code habe ich nun eingebaut, er funzt (fast) perfekt, allerdings hat er folgenden makel:

zu einem ausgewählten beitrag kommt ein kommentar oder auch mehrere.

weise ich mehrere kommentare einem beitrag zu, erscheint der beitrag soviel mal wie die zugewiesenen anzahl kommentare.

wie "filtere" ich diese überzähligen beiträge aus? also: beitrag+kommentar+kommentar+...+...
dieser letzte schritt bekomme ich nicht hin.

wo gehts lang? für hinweise: vielen dank.



$query = 'SELECT beitrag.id, kommentar.zu_id
. ' FROM beitrag'
. ' LEFT JOIN kommentar '

. ' ON beitrag.id = kommentar.zu_id'

. ' ORDER BY beitrag.datum DESC';

$result = mysql_query($query);
$num = mysql_numrows($result);

for ($i = 0; $i <$num; $i++)
{
$row = mysql_fetch_array($result);

echo beitrag;
echo kommentar;
}
X

doppelte ausgaben unterdrücken (LEFT JOIN+ON)

ganesh
Beiträge gesamt: 1981

17. Mai 2007, 16:48
Beitrag # 2 von 6
Beitrag ID: #292008
Bewertung:
(2328 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Ich mache jeweils 2 Queries bei so Sachen. z.B. wenn Du Monats- oder Jahres-Archive hast und der Monat oder das Jahr als Titel erscheinen soll.

Beispiel:

a) zuerst SELECT DISTINCT(YEAR(datum)) FROM ...

Ich hab nun einen Array. Den rattere ich dann durch nach Beiträgen (oder: in Deinem Fall: Kommentaren)

foreach($years as $key=>$jahr) {
// ein Query für alle Kommentare
}


als Antwort auf: [#291999]

doppelte ausgaben unterdrücken (LEFT JOIN+ON)

macmac
Beiträge gesamt: 394

17. Mai 2007, 20:46
Beitrag # 3 von 6
Beitrag ID: #292039
Bewertung:
(2313 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
hi

danke für die antwort. allerdings kann ich damit nichts anfangen.

wo kommt das denn hin? vor/nach/in meiner bestehenden query?


als Antwort auf: [#292008]

doppelte ausgaben unterdrücken (LEFT JOIN+ON)

ganesh
Beiträge gesamt: 1981

17. Mai 2007, 21:48
Beitrag # 4 von 6
Beitrag ID: #292047
Bewertung:
(2308 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Zuerst SELECT DISTINCT(beitrag) SORT BY whatever...
-> PHP-Array erzeugen aller Beiträge, z.B. $articles

Dann einen foreach-loop machen, wo Du alle Kommentare JE BEITRAG herausholst.

foreach($articles as $k=>$v) {
SELECT kommentar WHERE beitragID=$foo ORDER BY datum DESC
-> Schlaufe, bis alle Kommentare aufgelistet sind
}

$articles würde sinnigerweise grad ein multidim. Array sein: id-Nr. und Beitrags-Text


als Antwort auf: [#292039]

doppelte ausgaben unterdrücken (LEFT JOIN+ON)

macmac
Beiträge gesamt: 394

19. Mai 2007, 10:35
Beitrag # 5 von 6
Beitrag ID: #292245
Bewertung:
(2277 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
nachdem ich alles probiert habe, was ich mit meinem laienwissen kann, komme ich nicht zu keinem resultat. es leuchtet mir ein, zuerst einmal die beiden tabellen einzeln zu ordnen. also alle beiträge nach beitrag.id, danach alle kommentare nach dem kommentar.zu_id feld.

was ich in die foreach schleife schreiben muss, ist mir einfach nicht klar, zumal alle bücher immer die gleiche art beispiele ausgeben: was schreib ich rein?

foreach($articles .... und dann?) was ist $k=>$v?? wo nehm ich das aus meinen tabellen her? (meine zuordnung läuft ja: pro beitrag.id alle kommentare mit zu_id...
feldnamen könnens ja nicht sein - da kommen nur fehlermeldungen

was heisst $foo ??? was setz ich dort ein?, fragt der laie.

ich komme mit diesen angaben für profis nicht weiter. zwar lerne ich immer was, aber ich bleib def. stecken. die beiträge werden immer nach anzahl kommentare wiederholt – also alles beim alten.. :-(


als Antwort auf: [#292047]

doppelte ausgaben unterdrücken (LEFT JOIN+ON)

ganesh
Beiträge gesamt: 1981

22. Jun 2007, 10:59
Beitrag # 6 von 6
Beitrag ID: #298331
Bewertung:
(2170 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
@macmac:

Du hast mir heute eine private Nachricht geschickt, aber ich hab weder deine Email-Adresse, noch kann man Dir antworten ("der User macmac möchte keine private Nachrichten erhalten" -> ist zwar von HDS aus idiotisch; wieso kann man denn priv. Nachrichten überhaupt SENDEN???).


als Antwort auf: [#292245]
X

Aktuell

Web / SEO / Blockchain / Betriebssystem
300

Veranstaltungskalender

Hier können Sie Ihre Anlässe eintragen, welche einen Zusammenhang mit den Angeboten von HilfDirSelbst.ch wie z.B. Adobe InDesign, Photoshop, Illustrator, PDF, Pitstop, Affinity, Marketing, SEO, Büro- und Rechtsthemen etc. haben. Die Einträge werden moderiert freigeschaltet. Dies wird werktags üblicherweise innert 24 Stunden erfolgen.

pdf-icon Hier eine kleine Anleitung hinsichtlich Bedeutung der auszufüllenden Formularfelder.

Veranstaltungen
14.05.2024

Online
Dienstag, 14. Mai 2024, 10.00 - 10.30 Uhr

Webinar

Prozessoptimierung ist ein Teamsport! Keine Software und keine Maschine allein kann Ihnen helfen, die Effizienzpotenziale Ihres Betriebes maximal auszuschöpfen. Von der Auftragsannahme über die Vorstufe und den Druck bis hin zur Weiterverarbeitung – alles muss optimal ineinandergreifen. Apropos Weiterverarbeitung – in vielen Druckbetrieben fristet sie in Sachen Prozessoptimierung immer noch ein Schattendasein. Dabei liegen hier mittlerweile die größten Einsparpotenziale! In einem Webinar von Horizon und Impressed erfahren Sie, wie Sie diese Einsparungen realisieren können. Horizon, bekannt für innovative Lösungen in der Druckweiterverarbeitung, bietet mit iCE LiNK eine Workflowlösung für die Weiterverarbeitung. iCE LiNK überwacht, visualisiert und analysiert Produktionsabläufe und unterstützt bei der Wartung – damit immer alles reibungslos läuft. Den gleichen Anspruch hat der von Impressed entwickelte Impressed Workflow Server – er ist die smarte PDF-Workflow-Lösung für Druckereien, die Datenmanagement, Preflight und Produktionssteuerung übernimmt. Im Webinar zeigen Ihnen die Experten von Horizon und Impressed, wie beide Lösungen im Team die Effizienz und Produktivität Ihres Betriebes steigern können. Melden Sie sich am besten gleich an, wir freuen uns auf Sie! PS: Melden Sie sich in jedem Fall an – sollten Sie zum Termin verhindert sein, erhalten Sie die Aufzeichnung.

kostenlos

Ja

Organisator: Impressed / Horizon

https://www.impressed.de/schulung.php?c=sDetail&sid=327

Einsparpotenziale in der Weiterverarbeitung
Veranstaltungen
16.05.2024

Online
Donnerstag, 16. Mai 2024, 10.00 - 10.30 Uhr

Webinar

Komplizierte, kleinteilige Aufträge; alles sehr speziell; seit Jahren bewährte Prozesse – da können wir nichts standardisieren und automatisieren! Das sagen viele Großformatdrucker – aber stimmt das wirklich, ist dem tatsächlich so? Günther Business Solutions und Impressed treten in einem Webinar den Gegenbeweis an. Experten beider Unternehmen zeigen, wie Großformatdrucker vom Einsatz zweier bewährter Lösungen profitieren können: • von advanter print+sign von Günther Business Solutions, dem ERP-System für den Großformatdruck, dass alle Phasen der Wertschöpfung im Large Format Printing abdeckt • von Impressed Workflow Server, der smarten PDF-Workflow-Lösung für Druckereien, die Datenmanagement, Preflight und Produktionssteuerung übernimmt Über die Kombination beider Lösungen können Großformatdrucker ihre Prozesse mit modernen Workflows Schritt für Schritt automatisieren – und so zügig deutliche Zeit- und Kosteneinsparungen realisieren. Das Webinar sollten Sie sich nicht entgehen lassen – damit Sie keine Effizienzpotenziale mehr liegen lassen. Melden Sie sich am besten gleich an, wir freuen uns auf Sie! PS: Melden Sie sich in jedem Fall an – sollten Sie zum Termin verhindert sein, erhalten Sie die Aufzeichnung.

kostenlos

Nein

Organisator: Impressed / Günther Business Solutions

https://www.impressed.de/schulung.php?c=sDetail&sid=326

Und es geht doch: Automatisierung im Großformatdruck!