Skip to content

sonots/ruby-sql-maker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ruby-sql-maker

Build Status

SQL Builder for Ruby

Installation

Add the following to your Gemfile:

gem 'sql-maker'

And then execute:

$ bundle

Example

require 'sql-maker'
builder = SQL::Maker::Select.new(:quote_char => '"', :auto_bind => true)
builder.add_select('id').add_from('books').add_where('books.id' => 1).as_sql
#=> SELECT "id" FROM "books" WHERE "books"."id" = 1

To avoid quoting the column name, use sql_raw.

require 'sql-maker'
include SQL::Maker::Helper # adds sql_raw, etc
builder = SQL::Maker::Select.new(:quote_char => '"', :auto_bind => true)
builder.add_select(sql_raw('COUNT(*)')).add_from('books').as_sql
# => SELECT COUNT(*) FROM "books"

You may want to quote or escape on using sql_raw.

SQL::Maker::Quoting.quote("githubber's")  #=> 'githubber''s'
SQL::Maker::Quoting.escape("githubber's") #=> githubber''s

Further Reading

Please see the doc directory.

The JSON SQL Injection Vulnerability

Both perl and ruby verion of SQL::Maker has a JSON SQL Injection Vulnerability if not used in strict mode.

Therefore, I strongly recommend to use SQL::Maker in strict mode. You can turn on the strict mode by passing :strict => true as:

SQL::Maker.new(...., :strict => true)
SQL::Maker::Select.new(...., :strict => true)

In strict mode, array or hash conditions are not accepted anymore. A sample usage snippet is shown in below:

require 'sql-maker'
include SQL::Maker::Helper # adds SQL::QueryMaker functions such as sql_le, etc

builder = SQL::Maker::Select.new(:strict => true)

builder.select('user', ['*'], {:name => json['name']}) 
#=> SELECT * FROM `user` WHERE `name` = ?

builder.select('user', ['*'], {:name => ['foo', 'bar']})
#=> SQL::Maker::Error! Will not generate SELECT * FROM `name` IN (?, ?) any more

builder.select('user', ['*'], {:name => sql_in(['foo', 'bar'])})
#=> SELECT * FROM `user` WHERE `name` IN (?, ?)

builder.select('fruit', ['*'], {:price => sql_le(json['max_price'])})
#=> SELECT * FROM `fruit` WHERE `price` <= ?

See following articles for more details (perl version)

See Also

ChangeLog

See CHANGELOG.md for details.

ToDo

  1. Support plugins

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request

Copyright

Copyright (c) 2014 Naotoshi Seo. See LICENSE.txt for details.

Acknowledgement

Ruby SQL::Maker is a ruby port of following perl modules:

  1. https://github.com/tokuhirom/SQL-Maker
  2. https://github.com/kazuho/SQL-QueryMaker

Thank you very much!!!