Git Product home page Git Product logo

aggregations's Introduction

Advanced ActiveRecord Querying / Aggregations

Hey there! We're thoughtbot, a design and development consultancy that brings your digital product ideas to life. We also love to share what we learn.

This coding exercise comes from Upcase, the online learning platform we run. It's part of the Advanced ActiveRecord Querying course and is just one small sample of all the great material available on Upcase, so be sure to visit and check out the rest.

Exercise Intro

In this exercise, you'll learn how to use aggregate functions to run calculations like finding the maximum value in a data set.

Instructions

To start, you'll want to clone and run the setup script for the repo

git clone [email protected]:thoughtbot-upcase-exercises/aggregations.git
cd aggregations
bin/setup

After cloning and running bin/setup:

  • Review db/schema.rb to get a sense of the database schema you'll be querying.
  • Take a look at the classes in app/models to get familiar with the models and associations you'll be working with.
  • Edit spec/models/person_spec.rb and remove the pending line from the first spec.
  • Edit app/models/person.rb and implement maximum_salary_by_location to get the spec passing.
  • Edit spec/models/person_spec.rb and remove the other pending line.
  • Edit app/models/person.rb again and implement managers_by_salary_difference to make the spec pass.

You can run rake to re-run the tests at any time.

Once all the tests are passing (and there are no pending specs), you're all set!

Tips and Tricks

Watch the trail video on using custom joins and check out the documentation for the Calculations module.

Featured Solution

Check out the featured solution branch to see the approach we recommend for this exercise.

Forum Discussion

If you find yourself stuck, be sure to check out the associated Upcase Forum discussion for this exercise to see what other folks have said.

Next Steps

When you've finished the exercise, head on back to the Advanced ActiveRecord Querying course to find the next exercise, or explore any of the other great content on Upcase.

License

aggregations is Copyright © 2015-2018 thoughtbot, inc. It is free software, and may be redistributed under the terms specified in the LICENSE file.

Credits

thoughtbot

This exercise is maintained and funded by thoughtbot, inc.

The names and logos for Upcase and thoughtbot are registered trademarks of thoughtbot, inc.

aggregations's People

Contributors

jferris avatar christoomey avatar gabebw avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.