mirror of
https://github.com/silverstripe/silverstripe-postgresql
synced 2024-10-22 17:05:45 +02:00
BUG FIXE: Limit/offset fixed
This commit is contained in:
parent
05c47f09cb
commit
c3eb6d991f
@ -36,8 +36,22 @@ class PostgreSQLDatabase extends Database {
|
|||||||
*/
|
*/
|
||||||
private $database_original;
|
private $database_original;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This holds the parameters that the original connection was created with,
|
||||||
|
* so we can switch back to it if necessary (used for unit tests)
|
||||||
|
*/
|
||||||
private $parameters;
|
private $parameters;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* These two values describe how T-search will work.
|
||||||
|
* You can use either GiST or GIN, and '@@' (gist) or '@@@' (gin)
|
||||||
|
* Combinations of these two will also work, so you'll need to pick
|
||||||
|
* one which works best for you
|
||||||
|
*/
|
||||||
|
public $default_fts_cluster_method='GIN';
|
||||||
|
public $default_fts_search_method='@@@';
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Connect to a PostgreSQL database.
|
* Connect to a PostgreSQL database.
|
||||||
* @param array $parameters An map of parameters, which should include:
|
* @param array $parameters An map of parameters, which should include:
|
||||||
@ -252,26 +266,27 @@ class PostgreSQLDatabase extends Database {
|
|||||||
//for GiST searches
|
//for GiST searches
|
||||||
$fulltexts='';
|
$fulltexts='';
|
||||||
$triggers='';
|
$triggers='';
|
||||||
foreach($indexes as $name=>$this_index){
|
if($indexes){
|
||||||
if($this_index['type']=='fulltext'){
|
foreach($indexes as $name=>$this_index){
|
||||||
|
if($this_index['type']=='fulltext'){
|
||||||
|
|
||||||
//For full text search, we need to create a column for the index
|
//For full text search, we need to create a column for the index
|
||||||
$columns=explode(',', $this_index['value']);
|
$columns=explode(',', $this_index['value']);
|
||||||
for($i=0; $i<sizeof($columns);$i++)
|
for($i=0; $i<sizeof($columns);$i++)
|
||||||
$columns[$i]="\"" . trim($columns[$i]) . "\"";
|
$columns[$i]="\"" . trim($columns[$i]) . "\"";
|
||||||
|
|
||||||
$columns=implode(', ', $columns);
|
$columns=implode(', ', $columns);
|
||||||
|
|
||||||
$fulltexts .= "\"ts_$name\" tsvector, ";
|
$fulltexts .= "\"ts_$name\" tsvector, ";
|
||||||
$triggerName="ts_{$tableName}_{$name}";
|
$triggerName="ts_{$tableName}_{$name}";
|
||||||
|
|
||||||
$this->dropTrigger($triggerName, $tableName);
|
$this->dropTrigger($triggerName, $tableName);
|
||||||
$triggers.="CREATE TRIGGER $triggerName BEFORE INSERT OR UPDATE
|
$triggers.="CREATE TRIGGER $triggerName BEFORE INSERT OR UPDATE
|
||||||
ON \"$tableName\" FOR EACH ROW EXECUTE PROCEDURE
|
ON \"$tableName\" FOR EACH ROW EXECUTE PROCEDURE
|
||||||
tsvector_update_trigger(\"ts_$name\", 'pg_catalog.english', $columns);";
|
tsvector_update_trigger(\"ts_$name\", 'pg_catalog.english', $columns);";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if($indexes) foreach($indexes as $k => $v) $indexSchemas .= $this->getIndexSqlDefinition($tableName, $k, $v) . "\n";
|
if($indexes) foreach($indexes as $k => $v) $indexSchemas .= $this->getIndexSqlDefinition($tableName, $k, $v) . "\n";
|
||||||
|
|
||||||
$this->query("CREATE TABLE \"$tableName\" (
|
$this->query("CREATE TABLE \"$tableName\" (
|
||||||
@ -283,6 +298,8 @@ class PostgreSQLDatabase extends Database {
|
|||||||
if($triggers!=''){
|
if($triggers!=''){
|
||||||
$this->query($triggers);
|
$this->query($triggers);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $tableName;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -412,27 +429,23 @@ class PostgreSQLDatabase extends Database {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks a table's integrity and repairs it if necessary.
|
* Repairs and reindexes the table. This might take a long time on a very large table.
|
||||||
* @var string $tableName The name of the table.
|
* @var string $tableName The name of the table.
|
||||||
* @return boolean Return true if the table has integrity after the method is complete.
|
* @return boolean Return true if the table has integrity after the method is complete.
|
||||||
*/
|
*/
|
||||||
public function checkAndRepairTable($tableName) {
|
public function checkAndRepairTable($tableName) {
|
||||||
$this->runTableCheckCommand("VACUUM FULL \"$tableName\"");
|
$this->runTableCheckCommand("VACUUM FULL ANALYZE \"$tableName\"");
|
||||||
|
$this->runTableChechCommand("REINDEX TABLE \"$tableName\"");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper function used by checkAndRepairTable.
|
* Helper function used by checkAndRepairTable.
|
||||||
* @param string $sql Query to run.
|
* @param string $sql Query to run.
|
||||||
* @return boolean Returns if the query returns a successful result.
|
* @return boolean Returns true no matter what; we're not currently checking the status of the command
|
||||||
*/
|
*/
|
||||||
protected function runTableCheckCommand($sql) {
|
protected function runTableCheckCommand($sql) {
|
||||||
$testResults = $this->query($sql);
|
$testResults = $this->query($sql);
|
||||||
foreach($testResults as $testRecord) {
|
|
||||||
if(strtolower($testRecord['Msg_text']) != 'ok') {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -783,8 +796,15 @@ class PostgreSQLDatabase extends Database {
|
|||||||
|
|
||||||
if($asDbValue)
|
if($asDbValue)
|
||||||
return Array('data_type'=>'smallint');
|
return Array('data_type'=>'smallint');
|
||||||
else
|
else {
|
||||||
return 'smallint not null default ' . $default;
|
if($values['arrayValue']!='')
|
||||||
|
$default='';
|
||||||
|
else
|
||||||
|
$default=' default ' . (int)$values['default'];
|
||||||
|
|
||||||
|
return "smallint{$values['arrayValue']}" . $default;
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -799,7 +819,7 @@ class PostgreSQLDatabase extends Database {
|
|||||||
//$parts=Array('datatype'=>'date');
|
//$parts=Array('datatype'=>'date');
|
||||||
//DB::requireField($this->tableName, $this->name, "date");
|
//DB::requireField($this->tableName, $this->name, "date");
|
||||||
|
|
||||||
return 'date';
|
return "date{$values['arrayValue']}";
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -822,7 +842,7 @@ class PostgreSQLDatabase extends Database {
|
|||||||
|
|
||||||
if($asDbValue)
|
if($asDbValue)
|
||||||
return Array('data_type'=>'numeric', 'precision'=>'9');
|
return Array('data_type'=>'numeric', 'precision'=>'9');
|
||||||
else return 'decimal(' . $precision . ')';
|
else return "decimal($precision){$values['arrayValue']}";
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -834,8 +854,15 @@ class PostgreSQLDatabase extends Database {
|
|||||||
public function enum($values){
|
public function enum($values){
|
||||||
//Enums are a bit different. We'll be creating a varchar(255) with a constraint of all the usual enum options.
|
//Enums are a bit different. We'll be creating a varchar(255) with a constraint of all the usual enum options.
|
||||||
//NOTE: In this one instance, we are including the table name in the values array
|
//NOTE: In this one instance, we are including the table name in the values array
|
||||||
|
if(!isset($values['arrayValue']))
|
||||||
|
$values['arrayValue']='';
|
||||||
|
|
||||||
return "varchar(255) default '" . $values['default'] . "' check (\"" . $values['name'] . "\" in ('" . implode('\', \'', $values['enums']) . "'))";
|
if($values['arrayValue']!='')
|
||||||
|
$default='';
|
||||||
|
else
|
||||||
|
$default=" default '{$values['default']}'";
|
||||||
|
|
||||||
|
return "varchar(255){$values['arrayValue']}" . $default . " check (\"" . $values['name'] . "\" in ('" . implode('\', \'', $values['enums']) . "'))";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -853,7 +880,7 @@ class PostgreSQLDatabase extends Database {
|
|||||||
|
|
||||||
if($asDbValue)
|
if($asDbValue)
|
||||||
return Array('data_type'=>'double precision');
|
return Array('data_type'=>'double precision');
|
||||||
else return 'float';
|
else return "float{$values['arrayValue']}";
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -863,11 +890,16 @@ class PostgreSQLDatabase extends Database {
|
|||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public function int($values, $asDbValue=false){
|
public function int($values, $asDbValue=false){
|
||||||
//We'll be using an 8 digit precision to keep it in line with the serial8 datatype for ID columns
|
|
||||||
if($asDbValue)
|
if($asDbValue)
|
||||||
return Array('data_type'=>'numeric', 'precision'=>$values['precision']);
|
return Array('data_type'=>'numeric', 'precision'=>$values['precision']);
|
||||||
else
|
else {
|
||||||
return 'numeric(11) not null default ' . (int)$values['default'];
|
if($values['arrayValue']!='')
|
||||||
|
$default='';
|
||||||
|
else
|
||||||
|
$default=' default ' . (int)$values['default'];
|
||||||
|
|
||||||
|
return "numeric(11){$values['arrayValue']}" . $default;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -885,7 +917,7 @@ class PostgreSQLDatabase extends Database {
|
|||||||
if($asDbValue)
|
if($asDbValue)
|
||||||
return Array('data_type'=>'timestamp without time zone');
|
return Array('data_type'=>'timestamp without time zone');
|
||||||
else
|
else
|
||||||
return 'timestamp';
|
return "timestamp{$values['arrayValue']}";
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -902,7 +934,7 @@ class PostgreSQLDatabase extends Database {
|
|||||||
if($asDbValue)
|
if($asDbValue)
|
||||||
return Array('data_type'=>'text');
|
return Array('data_type'=>'text');
|
||||||
else
|
else
|
||||||
return 'text';
|
return "text{$values['arrayValue']}";
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -917,7 +949,7 @@ class PostgreSQLDatabase extends Database {
|
|||||||
//$parts=Array('datatype'=>'time');
|
//$parts=Array('datatype'=>'time');
|
||||||
//DB::requireField($this->tableName, $this->name, "time");
|
//DB::requireField($this->tableName, $this->name, "time");
|
||||||
|
|
||||||
return 'time';
|
return "time{$values['arrayValue']}";
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -936,7 +968,7 @@ class PostgreSQLDatabase extends Database {
|
|||||||
if($asDbValue)
|
if($asDbValue)
|
||||||
return Array('data_type'=>'varchar', 'precision'=>$values['precision']);
|
return Array('data_type'=>'varchar', 'precision'=>$values['precision']);
|
||||||
else
|
else
|
||||||
return 'varchar(' . $values['precision'] . ')';
|
return "varchar({$values['precision']}){$values['arrayValue']}";
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -945,7 +977,7 @@ class PostgreSQLDatabase extends Database {
|
|||||||
public function year($values, $asDbValue=false){
|
public function year($values, $asDbValue=false){
|
||||||
if($asDbValue)
|
if($asDbValue)
|
||||||
return Array('data_type'=>'numeric', 'precision'=>'4');
|
return Array('data_type'=>'numeric', 'precision'=>'4');
|
||||||
else return 'numeric(4)';
|
else return "numeric(4){$values['arrayValue']}";
|
||||||
}
|
}
|
||||||
|
|
||||||
function escape_character($escape=false){
|
function escape_character($escape=false){
|
||||||
@ -1055,8 +1087,12 @@ class PostgreSQLDatabase extends Database {
|
|||||||
if(!empty($combinedLimit)) $this->limit = $combinedLimit;
|
if(!empty($combinedLimit)) $this->limit = $combinedLimit;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
$limit=str_replace(',', ' OFFSET ', $sqlQuery->limit);
|
if(strpos($sqlQuery->limit, ',')){
|
||||||
$text .= " LIMIT " . $limit;
|
$limit=str_replace(',', ' LIMIT ', $sqlQuery->limit);
|
||||||
|
$text .= ' OFFSET ' . $limit;
|
||||||
|
} else {
|
||||||
|
$text.=' LIMIT ' . $sqlQuery->limit;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user