1. Dashboard
  2. Forum
    1. Unerledigte Themen
  3. Mitglieder
    1. Letzte Aktivitäten
    2. Benutzer online
    3. Team-Mitglieder
    4. Trophäen
    5. Mitgliedersuche
  4. Tutorial Bereich
  • Anmelden
  • Registrieren
  • Suche
Dieses Thema
  • Alles
  • Dieses Thema
  • Dieses Forum
  • Seiten
  • Forum
  • Lexikon
  • Erweiterte Suche
  1. Informatik Forum
  2. Webmaster & Internet
  3. Entwicklung

Query (für m:n relation)

  • davewood
  • 3. Oktober 2010 um 12:08
  • Unerledigt
  • davewood
    17
    davewood
    Mitglied
    Reaktionen
    9
    Punkte
    3.204
    Beiträge
    536
    • 3. Oktober 2010 um 12:08
    • #1

    Relationen:
    pictures --<>-- picture_tags --<>-- tags

    Input:
    Liste mit tags. zB (2,5,6)

    Query:
    Alle pictures mit tags (2,5,6)

    I like Toast!

  • davewood
    17
    davewood
    Mitglied
    Reaktionen
    9
    Punkte
    3.204
    Beiträge
    536
    • 3. Oktober 2010 um 12:11
    • #2

    Wer suchet der findet. :)

    http://stackoverflow.com/questions/1680…mn-relationship

    Code
    select *
    from pictures p
    where 3 = (
        select count(distinct t.id)
        from picture_tags pt
        inner join tags t on t.id = pt.tag_id
        where t.id in (2,5,6)
        and pt.picture_id = p.id
    )

    I like Toast!

    2 Mal editiert, zuletzt von davewood (3. Oktober 2010 um 12:31)

  • davewood
    17
    davewood
    Mitglied
    Reaktionen
    9
    Punkte
    3.204
    Beiträge
    536
    • 3. Oktober 2010 um 13:55
    • #3

    Und wer schreibt mir das jetzt als DBIx::Class search argument?

    ps: keine ernst gemeint Anfrage.

    I like Toast!

    Einmal editiert, zuletzt von davewood (3. Oktober 2010 um 14:50)

  • Christoph R.
    16
    Christoph R.
    Mitglied
    Reaktionen
    36
    Punkte
    2.626
    Beiträge
    428
    • 3. Oktober 2010 um 14:11
    • #4
    Zitat von davewood

    Und wer schreibt mir das jetzt als DBIx::Class search argument?



    Niemand, würde ich mal vermuten. Schon gar nicht wenn du die Frage so stellst als ob dir irgendjemand was schulden würde.

    Aber für den Anfang gebe ich dir einen Tipp: Sich im Internet eine fertige Query zu suchen (die zudem sicher auch einfacher geschrieben werden kann), und sie dann in irgendwas anderes übersetzen zu wollen, führt in der Regel nicht zum Ziel. Schau dir lieber die Grundlagen zur DBIx::Class ordentlich an und entwickle die Anfrage schrittweise.

  • davewood
    17
    davewood
    Mitglied
    Reaktionen
    9
    Punkte
    3.204
    Beiträge
    536
    • 3. Oktober 2010 um 14:49
    • #5

    Betrachte mein posting als Dialog mit mir selber. Ich erwarte mir nicht, dass jemand meine Arbeit erledigt schon gar nicht wenn ich's so fomuliere.

    Die DBIx::Class Dokumentation ist mir gut bekannt. Die Query allerdings nicht trivial und da ich schon ne Weile an dem Problem arbeite ist mir die Meldung quasi rausgerutscht.

    Sorry

    I like Toast!

    Einmal editiert, zuletzt von davewood (3. Oktober 2010 um 14:54)

  • davewood
    17
    davewood
    Mitglied
    Reaktionen
    9
    Punkte
    3.204
    Beiträge
    536
    • 3. Oktober 2010 um 18:00
    • #6

    Bringt nicht so viel aber wenn mal jemand drüberstolpern sollte.

    Code
    return $self->search(
               {
                   tag_id => { -in => \@tag_ids },
               },
               {
                   join        => 'picture_tags',
                   group_by    => ['me.id', 'me.name'],
                   having      => { 'count(tag_id)' => { '=', scalar @tag_ids } }
               }
           );

    I like Toast!

  • davewood
    17
    davewood
    Mitglied
    Reaktionen
    9
    Punkte
    3.204
    Beiträge
    536
    • 3. Oktober 2010 um 19:08
    • #7
    Code
    return $self->search (
                { map { 'picture_tags' . ($_ ? '_' . ($_+1) : '') . '.tag_id' => $enabled_tag_ids[$_] } (0 .. $#enabled_tag_ids) },
                { join => [ ('picture_tags') x @enabled_tag_ids ] }
            );

    multijoin much faster then group_by&having solution

    thanks to ribasushi @ #dbix-class

    ps: limit size of @enabled_tag_ids

    I like Toast!

  • Maximilian Rupp 27. Dezember 2024 um 00:26

    Hat das Thema aus dem Forum Programmieren nach Entwicklung verschoben.

Jetzt mitmachen!

Sie haben noch kein Benutzerkonto auf unserer Seite? Registrieren Sie sich kostenlos und nehmen Sie an unserer Community teil!

Benutzerkonto erstellen Anmelden

Rechtliches

Impressum

Datenschutzerklärung