aboutsummaryrefslogtreecommitdiffstats
path: root/lib/arel/nodes/extract.rb
diff options
context:
space:
mode:
authorAlexander Staubo <alex@origo.no>2012-02-23 14:06:05 +0100
committerAlexander Staubo <alex@origo.no>2012-02-23 14:06:05 +0100
commit2db4ec6a28a59a3f74a4979ae5bc117e5c7573c4 (patch)
tree8670d0a9f828d53faab7692ae7945836732e4ba4 /lib/arel/nodes/extract.rb
parenta1a6fbc189d0cb8c44606eafcb8bda7a010554c0 (diff)
downloadrails-2db4ec6a28a59a3f74a4979ae5bc117e5c7573c4.tar.gz
rails-2db4ec6a28a59a3f74a4979ae5bc117e5c7573c4.tar.bz2
rails-2db4ec6a28a59a3f74a4979ae5bc117e5c7573c4.zip
Add #extract, which produces ANSI SQL function EXTRACT(<field> from <expr>).
Diffstat (limited to 'lib/arel/nodes/extract.rb')
-rw-r--r--lib/arel/nodes/extract.rb23
1 files changed, 23 insertions, 0 deletions
diff --git a/lib/arel/nodes/extract.rb b/lib/arel/nodes/extract.rb
new file mode 100644
index 0000000000..1c9ee78816
--- /dev/null
+++ b/lib/arel/nodes/extract.rb
@@ -0,0 +1,23 @@
+module Arel
+ module Nodes
+
+ class Extract < Arel::Nodes::Unary
+ include Arel::Expression
+ include Arel::Predications
+
+ attr_accessor :field
+ attr_accessor :alias
+
+ def initialize expr, field, aliaz = nil
+ super(expr)
+ @field = field
+ @alias = aliaz && SqlLiteral.new(aliaz)
+ end
+
+ def as aliaz
+ self.alias = SqlLiteral.new(aliaz)
+ self
+ end
+ end
+ end
+end