Github Ds

A collection of Ruby libraries for working with SQL on top of ActiveRecord's connection
Alternatives To Github Ds
Project NameStarsDownloadsRepos Using ThisPackages Using ThisMost Recent CommitTotal ReleasesLatest ReleaseOpen IssuesLicenseLanguage
Ransack5,46514,9291642 months ago66May 25, 2022114mitRuby
Object-based searching.
Scenic3,236114143 months ago18February 13, 202223mitRuby
Versioned database views for Rails
Graphjin2,727223 days ago516June 03, 202328apache-2.0Go
GraphJin - Build NodeJS / GO APIs in 5 minutes not weeks
Lol_dba1,49337416 months ago35March 29, 202011Ruby
lol_dba is a small package of rake tasks that scan your application models and displays a list of columns that probably should be indexed. Also, it can generate .sql migration scripts.
663 days ago30January 14, 20221mitRuby
Just the right amount of Rails eager loading
Rails_db1,44143413 months ago41June 26, 20217mitJavaScript
Rails Database Viewer and SQL Query Runner
Activerecord Sqlserver Adapter953727288 hours ago145February 22, 202238mitRuby
SQL Server Adapter For Rails
Database_rewinder770490178 months ago34January 24, 202212mitRuby
minimalist's tiny and ultra-fast database cleaner
Github Ds667
22 months ago17April 07, 20216mitRuby
A collection of Ruby libraries for working with SQL on top of ActiveRecord's connection
Motor Admin Rails613
10 days ago198September 20, 20222agpl-3.0Ruby
Low-code Admin panel and Business intelligence Rails engine. No DSL - configurable from the UI. Rails Admin, Active Admin, Blazer modern alternative.
Alternatives To Github Ds
Select To Compare

Alternative Project Comparisons


GitHub::DS is a collection of Ruby libraries for working with SQL on top of ActiveRecord's connection.

  • GitHub::KV is a key/value data store backed by MySQL.
  • GitHub::SQL is for building and executing a SQL query. This class uses ActiveRecord's connection class, but provides a better API for bind values and raw data access.
  • GitHub::Result makes it easier to bake in resiliency through the use of a Result object instead of raising exceptions.

Current Status: Used in production extensively at GitHub. Because of this, all changes will be thoroughly vetted, which could slow down the process of contributing. We will do our best to actively communicate status of pull requests with any contributors. If you have any substantial changes that you would like to make, it would be great to first open an issue to discuss them with us.


Add this line to your application's Gemfile:

gem 'github-ds'

And then execute:

$ bundle

Or install it yourself as:

$ gem install github-ds


Below is a taste of what you can do with these libraries. If you want to see more, check out the examples directory.


First, you'll need to create the key_values table using the included Rails migration generator.

rails generate github:ds:active_record
rails db:migrate

If you need to change the name of the table used for storing the key-values, you can configure your table name as such, before running the migration:

GitHub::KV.configure do |config|
  config.table_name = "new_key_values_table"

Once you have created and executed the migration, KV can do neat things like this:

require "pp"

# Create new instance using ActiveRecord's default connection.
kv = { ActiveRecord::Base.connection }

# Get a key.
pp kv.get("foo")
#<GitHub::Result:0x3fd88cd3ea9c value: nil>

# Set a key.
kv.set("foo", "bar")
# nil

# Get the key again.
pp kv.get("foo")
#<GitHub::Result:0x3fe810d06e4c value: "bar">

# Get multiple keys at once.
pp kv.mget(["foo", "bar"])
#<GitHub::Result:0x3fccccd1b57c value: ["bar", nil]>

# Check for existence of a key.
pp kv.exists("foo")
#<GitHub::Result:0x3fd4ae55ce8c value: true>

# Check for existence of key that does not exist.
pp kv.exists("bar")
#<GitHub::Result:0x3fd4ae55c554 value: false>

# Check for existence of multiple keys at once.
pp kv.mexists(["foo", "bar"])
#<GitHub::Result:0x3ff1e98e18e8 value: [true, false]>

# Set a key's value if the key does not already exist.
pp kv.setnx("foo", "bar")
# false

# Delete a key.
pp kv.del("bar")
# nil

# Delete multiple keys at once.
pp kv.mdel(["foo", "bar"])
# nil

Note that due to MySQL's default collation, KV keys are case-insensitive.


# Select, insert, update, delete or whatever you need...
GitHub::SQL.results <<-SQL
  SELECT * FROM example_key_values
SQL <<-SQL, key: "foo", value: "bar"
  INSERT INTO example_key_values (`key`, `value`)
  VALUES (:key, :value)

GitHub::SQL.value <<-SQL, key: "foo"
  SELECT value FROM example_key_values WHERE `key` = :key

# Or slowly build up a query based on conditionals...
sql = <<-SQL
  SELECT `value` FROM example_key_values

key = ENV["KEY"]
unless key.nil?
  sql.add <<-SQL, key: key
    WHERE `key` = :key

limit = ENV["LIMIT"]
unless limit.nil?
  sql.add <<-SQL, limit: limit.to_i
    ORDER BY `key` ASC
    LIMIT :limit

p sql.results


def do_something

def do_something_that_errors
  raise "noooooppppeeeee"

result = { do_something }
p result.ok? # => true
p result.value! # => 1

result = { do_something_that_errors }
p result.ok? # => false
p result.value { "default when error happens" } # => "default when error happens"
  result.value! # raises exception because error happened
rescue => error
  p result.error
  p error

# Outputs Step 1, 2, 3
result = { { puts "Step 1: success!" }
}.then { |value| { puts "Step 2: success!" }
}.then { |value| { puts "Step 3: success!" }
p result.ok? # => true

# Outputs Step 1, 2 and stops.
result = { { puts "Step 1: success!" }
}.then { |value| {
    puts "Step 2: failed!"
}.then { |value| {
    puts "Step 3: should not get here because previous step failed!"
p result.ok? # => false


GitHub::KV Expiration

KV supports expiring keys and obeys expiration when performing operations, but does not actually purge expired rows. At GitHub, we use pt-archiver to nibble expired rows. We configure it to do a replica lag check and use the following options:

  • index_name: "index_key_values_on_expires_at"
  • limit: 1000
  • where: "expires_at <= NOW()"


After checking out the repo, run script/bootstrap to install dependencies. Then, run script/test to run the tests. You can also run script/console for an interactive prompt that will allow you to experiment.

Note: You will need a MySQL database with no password set for the root user for the tests. Running docker-compose up will boot just that. This functionality is not currently used by GitHub and was from a contributor, so please let us know if it does not work or gets out of date (pull request is best, but an issue will do).

To install this gem onto your local machine, run script/install. To release a new version, update the version number in version.rb, commit, and then run script/release, which will create a git tag for the version, push git commits and tags, and push the .gem file to


Bug reports and pull requests are welcome on GitHub at github/github-ds. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct. We recommend reading the contributing guide as well.


Nothing currently on our radar other than continued maintenance. Have a big idea? Let us know.


pic @mention
@haileysome @haileysome
@jnunemaker @jnunemaker
@miguelff @miguelff
@zerowidth @zerowidth


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

Popular Sql Projects
Popular Ruby On Rails Projects
Popular Data Processing Categories
Related Searches

Get A Weekly Email With Trending Projects For These Categories
No Spam. Unsubscribe easily at any time.
Ruby On Rails
Key Value