create sql part joining control code
Matt S Trout [Tue, 20 Aug 2019 00:45:33 +0000 (00:45 +0000)]
lib/SQL/Abstract.pm
lib/SQL/Abstract/Parts.pm [new file with mode: 0644]

index 0ffa4af..a906b57 100644 (file)
@@ -2,6 +2,7 @@ package SQL::Abstract; # see doc at end of file
 
 use strict;
 use warnings;
+use Module::Runtime ();
 use Carp ();
 use List::Util ();
 use Scalar::Util ();
@@ -239,6 +240,13 @@ sub new {
     ',' => '_render_op_multop',
   };
 
+  if ($opt{lazy_join_sql_parts}) {
+    my $mod = Module::Runtime::use_module('SQL::Abstract::Parts');
+    $opt{join_sql_parts} ||= sub { $mod->new(@_) };
+  }
+
+  $opt{join_sql_parts} ||= sub { join $_[0], @_[1..$#_] };
+
   return bless \%opt, $class;
 }
 
@@ -1198,7 +1206,7 @@ sub join_query_parts {
       : ((ref($_) eq 'ARRAY') ? $_ : [ $_ ])
   ), @parts;
   return [
-    join($join, map $_->[0], @final),
+    $self->{join_sql_parts}->($join, map $_->[0], @final),
     (map @{$_}[1..$#$_], @final),
   ];
 }
@@ -1315,7 +1323,9 @@ sub _order_by_chunks {
 
   return () unless defined(my $expanded = $self->_expand_order_by($arg));
 
-  return $self->_chunkify_order_by($expanded);
+  my @res = $self->_chunkify_order_by($expanded);
+  (ref() ? $_->[0] : $_) .= '' for @res;
+  return @res;
 }
 
 sub _chunkify_order_by {
diff --git a/lib/SQL/Abstract/Parts.pm b/lib/SQL/Abstract/Parts.pm
new file mode 100644 (file)
index 0000000..95f7069
--- /dev/null
@@ -0,0 +1,19 @@
+package SQL::Abstract::Parts;
+
+use strict;
+use warnings;
+
+use overload '""' => 'stringify', fallback => 1;
+
+sub new {
+  my ($proto, @args) = @_;
+  bless(\@args, ref($proto) || $proto);
+}
+
+sub stringify {
+  my ($self) = @_;
+  my ($join, @parts) = @$self;
+  return join $join, @parts;
+}
+
+1;