mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
BUGFIX: DataQuery overwriting _SortColumn selects (#8974)
* BUGFIX: DataQuery overwriting _SortColumn selects * FIX DataQuery _SortColumn handling
This commit is contained in:
parent
3a5c14f7c2
commit
3f1479edbb
@ -354,7 +354,6 @@ class DataQuery
|
|||||||
{
|
{
|
||||||
if ($orderby = $query->getOrderBy()) {
|
if ($orderby = $query->getOrderBy()) {
|
||||||
$newOrderby = array();
|
$newOrderby = array();
|
||||||
$i = 0;
|
|
||||||
foreach ($orderby as $k => $dir) {
|
foreach ($orderby as $k => $dir) {
|
||||||
$newOrderby[$k] = $dir;
|
$newOrderby[$k] = $dir;
|
||||||
|
|
||||||
@ -372,7 +371,6 @@ class DataQuery
|
|||||||
if (isset($originalSelect[$col])) {
|
if (isset($originalSelect[$col])) {
|
||||||
$query->selectField($originalSelect[$col], $col);
|
$query->selectField($originalSelect[$col], $col);
|
||||||
}
|
}
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -402,10 +400,15 @@ class DataQuery
|
|||||||
if (!in_array($qualCol, $query->getSelect())) {
|
if (!in_array($qualCol, $query->getSelect())) {
|
||||||
unset($newOrderby[$k]);
|
unset($newOrderby[$k]);
|
||||||
|
|
||||||
$newOrderby["\"_SortColumn$i\""] = $dir;
|
// Find the first free "_SortColumnX" slot
|
||||||
$query->selectField($qualCol, "_SortColumn$i");
|
// and assign it to $key
|
||||||
|
$i = 0;
|
||||||
|
while (isset($orderby[$key = "\"_SortColumn$i\""])) {
|
||||||
|
++$i;
|
||||||
|
}
|
||||||
|
|
||||||
$i++;
|
$newOrderby[$key] = $dir;
|
||||||
|
$query->selectField($qualCol, "_SortColumn$i");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -296,6 +296,32 @@ class DataQueryTest extends SapphireTest
|
|||||||
static::resetDBSchema(true);
|
static::resetDBSchema(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testSurrogateFieldSort()
|
||||||
|
{
|
||||||
|
$query = new DataQuery(DataQueryTest\ObjectE::class);
|
||||||
|
$query->sort(
|
||||||
|
sprintf(
|
||||||
|
'(case when "Title" = %s then 1 else 0 end)',
|
||||||
|
DB::get_conn()->quoteString('Second')
|
||||||
|
),
|
||||||
|
'DESC',
|
||||||
|
true
|
||||||
|
);
|
||||||
|
$query->sort('SortOrder', 'ASC', false);
|
||||||
|
$query->sort(
|
||||||
|
sprintf(
|
||||||
|
'(case when "Title" = %s then 0 else 1 end)',
|
||||||
|
DB::get_conn()->quoteString('Fourth')
|
||||||
|
),
|
||||||
|
'DESC',
|
||||||
|
false
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
$query->execute()->column('Title'),
|
||||||
|
$query->column('Title')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public function testComparisonClauseDateStartsWith()
|
public function testComparisonClauseDateStartsWith()
|
||||||
{
|
{
|
||||||
DB::query("INSERT INTO \"DataQueryTest_F\" (\"MyDate\") VALUES ('1988-03-04 06:30')");
|
DB::query("INSERT INTO \"DataQueryTest_F\" (\"MyDate\") VALUES ('1988-03-04 06:30')");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user