mirror of
				https://bitbucket.org/jsuto/piler.git
				synced 2025-10-26 07:32:28 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			107 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?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 />");
 | |
|       }
 | |
| 
 | |
| 
 | |
|       $this->affected = 0;
 | |
|    }
 | |
| 
 | |
| 
 | |
|    public function select_db($database) { }
 | |
| 
 | |
| 
 | |
|    public function query($sql, $arr = array()) {
 | |
|       $query = new stdClass();
 | |
| 
 | |
|       $query->error = 1;
 | |
|       $query->errmsg = "Error";
 | |
|       $query->query = $sql;
 | |
|       $query->total_found = 0;
 | |
| 
 | |
|       $time_start = microtime(true);
 | |
| 
 | |
|       $i = 0;
 | |
|       $data = array();
 | |
| 
 | |
|       $s = $this->link->prepare($sql);
 | |
|       if(!$s) { return $query; }
 | |
| 
 | |
|       $s->execute($arr);
 | |
| 
 | |
|       $this->affected = $s->rowCount();
 | |
| 
 | |
|       $R = $s->fetchAll();
 | |
| 
 | |
|       while(list ($k, $v) = each($R)){
 | |
|          $data[$i] = $v;
 | |
|          $i++;
 | |
|       }
 | |
| 
 | |
|       $query->row      = isset($data[0]) ? $data[0] : array();
 | |
|       $query->rows     = $data;
 | |
|       $query->num_rows = $i;
 | |
| 
 | |
|       $query->error = 0;
 | |
|       $query->errmsg = "";
 | |
| 
 | |
|       unset($data);
 | |
| 
 | |
|       $time_end = microtime(true);
 | |
| 
 | |
|       $query->exec_time = $time_end - $time_start;
 | |
| 
 | |
|       // 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
 | |
|       $meta = $this->link->prepare("SHOW META LIKE 'total_found'");
 | |
|       //$meta = $this->link->prepare("SHOW META");
 | |
| 
 | |
|       $meta->execute();
 | |
|       $R = $meta->fetchAll();
 | |
|       while(list ($k, $v) = each($R)){
 | |
|          if($v[0] == "total_found") { $query->total_found = $v[1]; }
 | |
|       }
 | |
| 
 | |
|       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)); }
 | |
| 
 | |
|       $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;
 | |
|    }
 | |
| 
 | |
| 
 | |
|    public function countAffected() {
 | |
|       return mysql_affected_rows($this->link);
 | |
|    }
 | |
| 
 | |
| 
 | |
|    public function getLastId() {
 | |
|       return mysql_insert_id($this->link);
 | |
|    }
 | |
| 
 | |
| 
 | |
|    public function __destruct() { }
 | |
| 
 | |
| }
 |