0.0
No release in over a year
SQL Template for Ruby
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

 Project Readme

[WIP]Super Template

This library not only can be used to generate sql, but also designed as a general template library.

Maintain your raw SQL logic in rails with plain old ruby object.

Every sql template is reusable, you don't need to write similar SQL logic again and again!

Inspired by ViewComponent

Installation

Add this line to your application's Gemfile:

gem "super_template"

And then execute:

$ bundle

Or install it yourself as:

$ gem install super_template

Quick start

A SuperTemplate is a Ruby object.

Templates are subclasses of SuperTemplate::Base and live in app/sqls.

Use the template generator to create a new Sql Template.

The generator accepts a folder name, template name and a list of arguments:

$ bin/rails generate component MySqlTemplate limit

    invoke  test_unit
    create  test/sqls/my_sql_template_test.rb
    create  app/sqls/my_sql_template.rb
    create  app/sqls/my_sql_template.sql.erb

If you want to generate files in another folder. you can execute:

$ bin/rails generate component MySqlTemplate limit --dir another_folder

    invoke  test_unit
    create  test/another_folder/my_sql_template_test.rb
    create  app/another_folder/my_sql_template.rb
    create  app/another_folder/my_sql_template.sql.erb

Template can be instantiated and passed to Rails' connection execute method:

ActiveRecord::Base.connection.execute(MySqlTemplate.new(limit: 10).call, {name: "dummy"})

Implementation

ActiveReocrd or Arel mode

Edit file app/sqls/my_sql_template.rb

class MySqlTemplate < SuperTemplate::Base

    def initialize(limit:)
        @limit = limit
    end

    def render_template
        MyTable.limit(@limit).all.to_sql
    end
end

Inline style

Edit file app/sqls/my_sql_template.rb

class MySqlTemplate < SuperTemplate::Base
    erb_template <<-ERB
        SELECT * FROM my_table WHERE col = :name limit <%= @limit %>
    ERB

    def initialize(limit:)
        @limit = limit
    end
end

Template File

Edit file app/sqls/my_sql_template.html.erb

SELECT * FROM my_table WHERE col = :name limit <%= @limit %>

Edit file app/sqls/my_sql_template.rb

class MySqlTemplate < SuperTemplate::Base
    def initialize(limit:)
        @limit = limit
    end
end

Call Super

Edit file app/sqls/sub_sql_template.rb

class SubSqlTemplate < SuperTemplate::Base
    def initialize(limit:, offset:)
        super(limit: limit)
        @offset = offset
    end
    template :erb, <<~ERB
    <%= super %> limit <%= @offset %>
    ERB
end

Contributing

Contribution directions go here.

License

The gem is available as open source under the terms of the MIT License.