1
# Copyright (c) 2008, 2011 Oracle and/or its affiliates. All rights reserved.
2
# Use is subject to license terms.
4
# This program is free software; you can redistribute it and/or modify
5
# it under the terms of the GNU General Public License as published by
6
# the Free Software Foundation; version 2 of the License.
8
# This program is distributed in the hope that it will be useful, but
9
# WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11
# General Public License for more details.
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301
18
package GenTest::Transform::OrderBy;
21
@ISA = qw(GenTest GenTest::Transform);
27
use GenTest::Transform;
28
use GenTest::Constants;
32
my ($class, $original_query) = @_;
34
my @selects = $original_query =~ m{(SELECT)}sgio;
36
if ($original_query =~ m{GROUP\s+BY}io) {
37
return STATUS_WONT_HANDLE;
38
} elsif ($original_query =~ m{ORDER\s+BY[^()]*CONCAT\s*\(}sio) {
39
# CONCAT() in ORDER BY requires more complex regexes below
40
# for correct behavior, so we skip this query.
41
return STATUS_WONT_HANDLE;
43
my $transform_outcome;
44
if ($original_query =~ m{LIMIT[^()]*$}sio) {
45
$transform_outcome = "TRANSFORM_OUTCOME_SUPERSET";
47
if ($original_query =~ s{ORDER\s+BY[^()]*$}{}sio) {
49
} elsif ($#selects == 0) {
50
return STATUS_WONT_HANDLE if $original_query !~ s{LIMIT[^()]*$}{ORDER BY 1}sio;
52
return STATUS_WONT_HANDLE;
55
$transform_outcome = "TRANSFORM_OUTCOME_UNORDERED_MATCH";
57
if ($original_query =~ s{ORDER\s+BY[^()]*$}{}sio) {
59
} elsif ($#selects == 0) {
60
return STATUS_WONT_HANDLE if $original_query !~ s{$}{ ORDER BY 1}sio;
61
# Add ORDER BY 1 (no LIMIT)
63
return STATUS_WONT_HANDLE;
67
return $original_query." /* $transform_outcome */ ";