Phalcon - Abfragesprache
Phalcon Query Language (PHQL) wird auch als bezeichnet PhalconQL ist ein SQL-Dialekt auf hoher Ebene, der SQL-Abfragen für die von Phalcon unterstützten Datenbanksysteme standardisiert.
Es enthält einen in C geschriebenen Parser, der die Syntax im Ziel-RDBMS übersetzt.
Hier ist eine Liste einiger der wichtigsten Funktionen der Phalcon-Abfragesprache:
Zur Sicherheit der Webanwendung werden gebundene Parameter verwendet.
Tabellen werden als Modelle behandelt, während Spalten als Klassenattribute behandelt werden.
Alle Datenmanipulationsanweisungen werden verwendet, um Datenverluste zu vermeiden, die auftreten können.
Die SQL-Injection wird verhindert, indem der SQL-Abfrageaufruf einzeln ausgeführt wird.
Erstellen einer PHQL-Abfrage
Abfragen werden durch Instanziieren der Klasse erstellt Phalcon\Mvc\Model\Query.
Beispiel
// Instantiate the Query
$query = new Query(
"SELECT * FROM Users",
$this->getDI()
);
// Execute the query returning a result if any
$cars = $query->execute();
In den vorherigen Kapiteln haben wir die Funktionsweise der Gerüst-Webanwendung mit dem Namen Blog-Tutorial gesehen. Es beinhaltete die Suche nach Kategorien nach Namen oder Slug.
Im Folgenden finden Sie den Code für searchAction.
public function searchAction() {
$numberPage = 1;
if ($this->request->isPost()) {
$query = Criteria::fromInput($this->di, "Categories", $_POST);
$this->session->conditions = $query->getConditions();
} else {
$numberPage = $this->request->getQuery("page", "int");
if ($numberPage <= 0) {
$numberPage = 1;
}
}
$parameters = array();
if ($this->session->conditions) {
$parameters["conditions"] = $this->session->conditions;
}
// $parameters["order"] = "id";
$categories = Categories::find($parameters);
if (count($categories) == 0) {
$this->flash->notice("The search did not find any categories");
return $this->dispatcher->forward(array(
"controller" => "categories",
"action" => "index"
));
}
$paginator = new \Phalcon\Paginator\Adapter\Model(array(
"data" => $categories,
"limit"=> 10,
"page" => $numberPage
));
$page = $paginator->getPaginate();
$this->view->setVar("page", $page);
}
Die im Controller ausgeführte (hervorgehobene) PHQL-Abfrage ruft alle Ergebnisse gemäß der Suchbedingung ab. Das Ergebnis einer Suchabfrage gemäß der Bedingung wird wie im Screenshot angezeigt.
Es folgt die Ausgabe, die bei erfolgreicher Ausführung des obigen Codes empfangen wurde.
PHQL-Lebenszyklus
Als Hochsprache bietet PHQL den Entwicklern die Möglichkeit, verschiedene Aspekte gemäß den Anforderungen zu personalisieren und anzupassen.
Es folgt der Lebenszyklus jeder in Phalcon ausgeführten PHQL-Anweisung -
Jede PHQL-Anweisung wird analysiert und als Intermediate Representation (IR) konvertiert, die völlig unabhängig von der vom Datenbanksystem implementierten SQL ist.
Die IR wird gemäß dem in der Webanwendung verwendeten Datenbanksystem in eine SQL-Anweisung konvertiert. Generierte SQL-Anweisungen sind dem Modell zugeordnet.
Alle PHQL-Anweisungen werden einmal analysiert und im Speicher zwischengespeichert. Wenn dasselbe Anweisungsergebnis ausgeführt wird, trägt dies zu einer schnelleren Leistung bei.