piler/webui/system/database/sphinx.php

109 lines
2.5 KiB
PHP
Raw Permalink Normal View History

2012-02-08 23:14:28 +01:00
<?php
class Sphinx {
private $link;
private $prefix;
public function __construct($hostname, $username, $password, $database, $prefix = NULL) {
list($host, $port) = explode(":", $hostname);
try {
$this->link = new PDO("mysql:host=$host;port=$port;dbname=$database;charset=" . DB_CHARSET, $username, $password);
}
catch(PDOException $exception) {
exit('Error: ' . $exception->getMessage() . " on database: $database<br />");
2012-02-08 23:14:28 +01:00
}
$this->affected = 0;
2012-02-08 23:14:28 +01:00
}
public function select_db($database) { }
public function query($sql, $arr = array()) {
2012-02-08 23:14:28 +01:00
$query = new stdClass();
$query->error = 1;
$query->errmsg = "Error";
2012-02-08 23:14:28 +01:00
$query->query = $sql;
$query->total_found = 0;
2012-02-08 23:14:28 +01:00
$time_start = microtime(true);
$i = 0;
$data = array();
2012-02-08 23:14:28 +01:00
$s = $this->link->prepare($sql);
if(!$s) { return $query; }
2012-02-08 23:14:28 +01:00
if(!$s->execute($arr)) {
syslog(LOG_INFO, $s->errorInfo()[2]);
}
2012-02-08 23:14:28 +01:00
$this->affected = $s->rowCount();
2012-02-08 23:14:28 +01:00
$R = $s->fetchAll();
2012-02-08 23:14:28 +01:00
foreach($R as $k => $v) {
$data[$i] = $v;
$i++;
}
2012-02-08 23:14:28 +01:00
$query->row = isset($data[0]) ? $data[0] : array();
$query->rows = $data;
$query->num_rows = $i;
2012-02-08 23:14:28 +01:00
$query->error = 0;
$query->errmsg = "";
2012-02-08 23:14:28 +01:00
unset($data);
2012-02-08 23:14:28 +01:00
$time_end = microtime(true);
2012-02-08 23:14:28 +01:00
$query->exec_time = $time_end - $time_start;
2012-02-08 23:14:28 +01:00
// Use the commented out line if you still have sphinx 2.0.x
// and use select * from in model/search/search.php in line 232
2015-08-11 15:16:13 +02:00
$meta = $this->link->prepare("SHOW META LIKE 'total_found'");
//$meta = $this->link->prepare("SHOW META");
$meta->execute();
2013-12-25 16:26:09 +01:00
$R = $meta->fetchAll();
foreach($R as $k => $v) {
2015-08-11 15:16:13 +02:00
if($v[0] == "total_found") { $query->total_found = $v[1]; }
2013-12-25 16:26:09 +01:00
}
if(LOG_LEVEL >= NORMAL) { syslog(LOG_INFO, sprintf("sphinx query: '%s' in %.2f s, %d hits, %d total found", $query->query, $query->exec_time, $query->num_rows, $query->total_found)); }
2015-08-11 15:16:13 +02:00
$session = Registry::get('session');
$sphx_query = '';
$b = preg_split("/\ ORDER\ /", $query->query);
$a = preg_split("/\ WHERE\ /", $b[0]);
if(isset($a[1])) {
$sphx_query = preg_replace("/\'/", "\'", $a[1]);
}
$session->set("sphx_query", $sphx_query);
return $query;
2012-02-08 23:14:28 +01:00
}
public function countAffected() {
return mysql_affected_rows($this->link);
}
public function getLastId() {
return mysql_insert_id($this->link);
}
2012-02-08 23:14:28 +01:00
public function __destruct() { }
2012-02-08 23:14:28 +01:00
}