Hallo an die Liste, falls dieser Post schonmal in der Liste erschienen sein sollte, bitte ich um Entschuldigung, ich bekomme ihn nicht in meinen Mails angezeigt (diesmal hoffentlich). Ich habe eine Frage zu Extbase und hoffe, jemand kann mir helfen: Ich möchte eine direkte SQL-Abfrage schreiben, da die Repository-Methoden in diesem Fall zu kurz greifen.
Ich möchte die Abfrage als prepared statement abschicken, etwa so (nur zur Veranschaulichung des Problems, die eigentliche Abfrage ist komplexer): $suchString = $uebergebenerSuchparameter; $query = $this->createQuery(); $query->getQuerySettings()->usePreparedStatement(TRUE); $sql = 'SELECT DISTINCT tabelle.* from tabelle as objekt WHERE objekt.name LIKE ?' $query->statement($sql, array("%$suchString%")); return $query->execute(); Die Verarbeitung des Fragezeichens als Platzhalter funktioniert so aber leider nicht; Ich erhalte einen SQL-Fehler: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '? Beim Debuggen über Extbase zeigt sich ebenfalls, dass das Fragezeichen nicht ersetzt wird. Anmerkungen: 1. Die SQL-Syntax (mit Ausnahme des nicht verarbeiteten Fragezeichens) ist bei allen getesteten Abfragen korrekt: Wenn ich die Variable und die Begrenzer direkt in die Abfrage schreibe, funktioniert alles. 2. Unter TYPO3 6.2 funktioniert die Abfrage über das prepared statement noch. 3. Ich habe gesehen, dass ab Version 7.0 für das Binden von Parametern prepared statements verwendet werden müssen. Heißt dass, dass ich das entsprechende Kernobjekt selbst bauen muss? Hat jemand eine Idee, wie sich die prepared statements umsetzen lassen? Vielen Dank für Tips, Mit freundlichen Grüßen Alexander Künzl _______________________________________________ TYPO3-german mailing list TYPO3-german@lists.typo3.org http://lists.typo3.org/cgi-bin/mailman/listinfo/typo3-german