my ($self, $setop, $args) = @_;
$self->join_query_parts(
' '.$self->format_keyword(join '_', $setop, ($args->{type}||())).' ',
- map [ $self->render_aqt($_) ], @{$args->{queries}}
+ @{$args->{queries}}
);
}) for qw(union intersect except);
[ $self->join_query_parts(' ',
[ $self->_render_alias($alias) ],
[ $self->format_keyword('as') ],
- [ $self->render_aqt($query) ],
+ $query,
) ]
} @{$with->{queries}}
) ];
return $self;
}
-sub format_keyword { $_[0]->_sqlcase(join ' ', split '_', $_[1]) }
-
sub _expand_select_clause_from {
my ($self, undef, $from) = @_;
+(from => $self->_expand_from_list(undef, $from));
sub _render_from_list {
my ($self, undef, $list) = @_;
- return $self->join_query_parts(', ', map [ $self->render_aqt($_) ], @$list);
+ return $self->join_query_parts(', ', @$list);
}
sub _render_join {
my ($as, @cols) = @$args;
return (@cols
? $self->join_query_parts('',
- [ $self->render_aqt($as) ],
+ $as,
[ '(' ],
[ $self->join_query_parts(
', ',
- map [ $self->render_aqt($_) ], @cols
+ @cols
) ],
[ ')' ],
)