DistroPropaganda/code/rails40/e1/ar/find_examples.rb
2018-11-24 13:20:20 +01:00

111 lines
3.6 KiB
Ruby

#---
# Excerpted from "Agile Web Development with Rails",
# published by The Pragmatic Bookshelf.
# Copyrights apply to this code. It may not be used to create training material,
# courses, books, articles, and the like. Contact us if you are in doubt.
# We make no guarantees that this code is fit for any purpose.
# Visit http://www.pragmaticprogrammer.com/titles/rails4 for more book information.
#---
$: << File.dirname(__FILE__)
require "connect"
require "logger"
ActiveRecord::Base.logger = Logger.new(STDERR)
require "rubygems"
require "active_record"
require "pp"
@params = {}
def params
@params
end
class Order < ActiveRecord::Base
named_scope :check, :conditions => {:pay_type => 'check'}
named_scope :cc, :conditions => {:pay_type => 'cc'}
named_scope :po, :conditions => {:pay_type => 'po'}
end
class Order < ActiveRecord::Base
named_scope :recent, :conditions => ['created_at > ?', 1.week.ago]
named_scope :since, lambda { |range|
{ :conditions => ['created_at > ?', range] }
}
end
class LineItem < ActiveRecord::Base
end
class Product < ActiveRecord::Base
end
# return an arbitrary order
order = Order.find(:first)
# return an order for Dave
order = Order.find(:first, :conditions => "name = 'Dave Thomas'")
# return the latest order for Dave
order = Order.find(:first,
:conditions => "name = 'Dave Thomas'",
:order => "id DESC")
orders = LineItem.find_by_sql("select line_items.* from line_items, orders " +
" where order_id = orders.id " +
" and orders.name = 'Dave Thomas' ")
orders = Order.find_by_sql("select name, pay_type from orders")
first = orders[0]
p first.attributes
p first.attribute_names
p first.attribute_present?("address")
p Order.all
p Order.check(:order => "created_on desc").first
p Order.po.recent.count
p Order.check.find_by_name('Dave Thomas')
p Order.po.recent(:order => :created_at)
p Order.po.since(1.week.ago)
LineItem.delete_all
Product.delete_all
p = Product.create(:title => "Programming Ruby", :price => 49.95)
LineItem.create(:quantity => 2, :product_id => p.id, :order_id => first)
items = LineItem.find_by_sql("select *, " +
" products.price as unit_price, " +
" quantity*products.price as total_price, " +
" products.title as title " +
" from line_items, products " +
" where line_items.product_id = products.id ")
li = items[0]
puts "#{li.title}: #{li.quantity}x#{li.unit_price} => #{li.total_price}"
c1 = Order.count
c2 = Order.count(:conditions => ["name = ?", "Dave Thomas"])
c3 = LineItem.count_by_sql("select count(*) " +
" from line_items, orders " +
" where line_items.order_id = orders.id " +
" and orders.name = 'Dave Thomas' ")
puts "Dave has #{c3} line items in #{c2} orders (#{c1} orders in all)"
order = Order.find_by_name("Dave Thomas")
orders = Order.find_all_by_name("Dave Thomas")
orders = Order.find_all_by_email(params['email'])
o = LineItem.find(:all,
:conditions => "pr.title = 'Programming Ruby'",
:joins => "inner join products as pr on line_items.product_id = pr.id")
p o.size
LineItem.delete_all
res = Order.update_all("pay_type = 'wibble'")
p res
res = Order.delete_all(["pay_type = ?", "wibble"])
p res