• Jeder User im Forum verpflichtet sich zur Akzeptanz und zur Einhaltung dieser Regeln:
    1. Umgangston
      Ein angemessener höflicher Umgangston, ohne Beleidigungen, Beschimpfungen und aggressive Postings ist für jedes Mitglied Pflicht.
    2. Beiträge
      Jedes Mitglied sollte sich bemühen nur sinnvolle Beiträge zum Thema zu posten. Dabei ist unbedingt vorher zu prüfen, ob das Thema vorher schon einmal diskutiert wurde und daher fortgesetzt werden kann
      • Suchfunktion benutzen!
      • offizielle Doku lesen!
    3. Haftung
      Jeder Beitragsersteller übernimmt die alleinige Verantwortung seiner Inhalte.
    4. Werbung
      Wir erlauben keine Beiträge, Signaturen, Private Nachrichten oder eMails an Benutzer, die Werbung enthalten. Ausgenommen
      sind Stellengesuche /-angebote, welche ausschließlich im Forum "Stellengesuche" veröffentlicht werden dürfen.
    5. Verstöße
      Regelwidrige Beiträge sollten dem Team gemeldet werden. Nach deren Überprüfung werden wir schnellstmöglich
      entsprechend handeln.
    6. Authorität
      Den Anweisungen der Team-Mitglieder (Administratoren und Moderatoren) sind in diesem Forum Folge zu leisten.
      Bei Fragen oder Beschwerden bitte an diese wenden.
    Wir möchten Euch darauf aufmerksam machen, dass es bei Verstößen gegen einen oder mehreren der oben genannten
    Punkte dem Team frei steht entsprechend zu handeln. Dies kann z.B. das Löschen eines Beitrags, das Ausschliessen bzw.
    Sperren von Mitgliedern oder aber lediglich eine Verwarnung sein.

    In diesem Zusammenhang sollte erwähnt werden, dass das Forum automatisch die IP-Adresse jedes Beitrag-Erstellers
    speichert. Bei schweren Vergehen, behalten wir es uns vor, die IP-Adresse zur Strafverfolgung weiterzugeben.
  • Willkommen im Zend Framework Forum

    ZF1 Zend Framework 1 + ZF2 Zend Framework 2

    Das Zend Framework Forum ist seit 2006 die erste Anlaufstelle für Zend Framework Entwickler in Deutschland. Mit über 70.000 Beiträgen und einer steigenden Nutzerzahl bietet das Forum hilfreiche Themen und ZF-Tutorials für professionelle Entwickler, fortgeschrittene Programmierer sowie Zend Framework Einsteiger.
    Wenn dies Dein erster Besuch in der Zend Framework Community ist, lies bitte zuerst die Hilfe - FAQ durch. Du musst Dich registrieren, bevor Du Beiträge verfassen kannst. Klicke oben auf 'Registrieren', um die Registrierung zu starten. Du kannst auch jetzt schon Beiträge lesen. Hier im Forum findest Du die Zend Framework Hilfe, die Du suchst!

    Grüße an alle Zend Framework Entwickler. Das Team vom Zend Framework Forum!

    Drupal Agentur

ibmDb2 Select limit funktioniert nicht

isac91

New member
Hallo Community,
ich habe ein weiteres Problem bei meiner Datenbankabfrage.
Und zwar möchte ich die Abfrage auf 50 Datensätze begrenzen.
Bevor ich Zend\Db\Sql genutzt habe (und das SQL von Hand zu Fuß erstellt habe) sah das ganze so aus:
Code:
Select ... From .... Where ... Order by.... fetch FIRST 50 ROWS ONLY
Nun nutze ich jedoch Zend\Db\Sql\Select. Hier gibt es zwar die Limit Funktion, die jedoch anscheinend nicht auf ibmDb2 angepasst wurde.
Denn wenn ich folgende Abfrage machen möchte:
PHP:
//...
$select->where($where);
$select->order("ORDER BY....");
$select->limit(50);
Wird mir ein SQL erzeugt, welches auf
Order by ... LIMIT '50'
endet.
Bei db2 gibt es die Limit funktion jedoch nicht und ich bekomme die Fehlermeldung:
Warning: Invalid argument supplied for foreach() in /www/zendsvr/htdocs/Projektverwaltung/vendor/zendframework/zendframework/library/Zend/Db/Sql/Platform/IbmDb2/SelectDecorator.php on line 116
Ich bin auch schon länger auf der Suche und habe unter anderem folgendes gefunden:https://github.com/zendframework/zf2/issues/6369
Wenn ich es richtig sehe, sollte dieses Problem schon seit längerem gefixt sein, ist es aber mmn nicht.

Jemand eine Idee wie ich diese Limitierung setzen kann?
Danke
 

isac91

New member

isac91

New member
Vergleiche mal deine erstelltes SQL-Objekt mit den Unit Tests, vielleicht findest du dort einen Ansatz.
Habe nun mal alles verglichen und tatsächlich habe ich es nun zum laufen bekommen..allerdings immernoch nicht komplett wie gewollt.
Problem war folgende Zeile:
PHP:
$select->quantifier(Select::QUANTIFIER_DISTINCT);
Die aus meinem Select ein Select Distinct macht.

Nun habe ich also mein Limit, aber kein Distinct mehr in meiner Abfrage

EDIT
Habe es nun mal folgendermaßen eingebaut:
PHP:
 $select->columns(array('NR' => new Expression('DISTINCT IDENTNR'),
 
Zuletzt bearbeitet:
Oben