diff options
author | Nikolay Shebanov <nikolay.shebanov@gmail.com> | 2014-03-03 15:54:52 +0300 |
---|---|---|
committer | Nikolay Shebanov <nikolay.shebanov@gmail.com> | 2014-03-06 00:05:39 +0400 |
commit | d361d9303b3673f73d541ffe0c5e0e81abe5391c (patch) | |
tree | f295f608d8878daa118837283d42affce309e7eb | |
parent | 409fbffc92dfe612db129d5bb4e99a8807854958 (diff) | |
download | rails-d361d9303b3673f73d541ffe0c5e0e81abe5391c.tar.gz rails-d361d9303b3673f73d541ffe0c5e0e81abe5391c.tar.bz2 rails-d361d9303b3673f73d541ffe0c5e0e81abe5391c.zip |
[ci skip] Add "Low-Level Caching" part to "Caching With Rails"
-rw-r--r-- | guides/source/caching_with_rails.md | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/guides/source/caching_with_rails.md b/guides/source/caching_with_rails.md index 0d45e5fb28..e898d75d1a 100644 --- a/guides/source/caching_with_rails.md +++ b/guides/source/caching_with_rails.md @@ -140,6 +140,26 @@ You can also combine the two schemes which is called "Russian Doll Caching": It's called "Russian Doll Caching" because it nests multiple fragments. The advantage is that if a single product is updated, all the other inner fragments can be reused when regenerating the outer fragment. +### Low-Level Caching + +Sometimes you need to cache a particular value or query result, instead of caching view fragments. Rails caching mechanism works great for storing __any__ kind of information. + +The most efficient way to implement low-level caching is using the `Rails.cache.fetch` method. This method does both reading and writing to the cache. When passed only a single argument, the key is fetched and value from the cache is returned. If a block is passed, the result of the block will be cached to the given key and the result is returned. + +Consider the following example. An application has a `Product` model with an instance method that looks up the product’s price on a competing website. The data returned by this method would be perfect for low-level caching: + +```ruby +class Product < ActiveRecord::Base + def competing_price + Rails.cache.fetch("#{cache_key}/competing_price", expires_in: 12.hours) do + Competitor::API.find_price(id) + end + end +end +``` + +NOTE: Notice that in this example we used `cache_key` method, so the resulting cache-key will be something like `products/233-20140225082222765838000/competing_price`. `cache_key` generates a string based on the model’s `id` and `updated_at` attributes. This is a common convention and has the benefit of invalidating the cache whenever the product is updated. In general, when you use low-level caching for instance level information, you need to generate a cache key. + ### SQL Caching Query caching is a Rails feature that caches the result set returned by each query so that if Rails encounters the same query again for that request, it will use the cached result set as opposed to running the query against the database again. |