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

Antwort per Email an