2009/7/31 Italo Matos <[email protected]>: > > i want to list every libraries, > but only show the your books with more than > 100 pages. >
I understand now. I can not immediately see how to do that in one query. Anyone else? You are _still_ top posting. It makes it much more difficult for someone who has not been following the thread to pick it up and help. Colin > > > > On 31 jul, 18:15, Colin Law <[email protected]> wrote: >> 2009/7/31 Italo Matos <[email protected]>: >> >> >> >> > but, if me put the conditions in find method, >> > it will filter much libraries ( if libraries has more one book with >> > more than 100 pages ). >> >> I don't understand. Your original query would give you everything, the >> modified one will only give you Libraries and books with greater than >> 100 pages which is what I thought you asked for. To quote 'i would >> like to create a xml with all Libraries, but books with pages more >> than 100'. Perhaps I do not understand exactly what you mean, could >> you give a more detailed example of what you want? >> >> Colin >> >> >> >> > On 31 jul, 17:10, Colin Law <[email protected]> wrote: >> >> 2009/7/31 Italo Matos <[email protected]>: >> >> >> > I can`t put the conditionbs in the Library.find, because this >> >> > relashionship is uses in other part of code. >> >> > How to call named scope in this case? >> >> >> I meant use render :xml=> Library.find(:all, :include => :books, >> >> :conditions => ['books.pages >= ?', 100]).to_xml(:include=>books) >> >> >> Or define a named_scope books_with_more_than_100_pages, though I >> >> suspect you would actually parameterise this, then >> >> render :xml=> >> >> Library.books_with_more_than_100_pages.to_xml(:include=>books) >> >> >> The above not tested so probably full of typos. >> >> >> By the way it is generally frowned upon to top post in this list. >> >> >> Colin >> >> >> > On 31 jul, 16:44, Colin Law <[email protected]> wrote: >> >> >> 2009/7/31 Italo Matos <[email protected]>: >> >> >> >> > i have: >> >> >> >> > class Library << ActiveRecord::Base >> >> >> > has_many :books >> >> >> > end >> >> >> >> > class Book << ActiveRecord::Base >> >> >> > belongs_to :library >> >> >> > end >> >> >> >> > in my controller i have: >> >> >> >> > render :xml=> Library.find(:all).to_xml(:include=>books) >> >> >> > but, i would like put a condition in the books ( e.: pages >= 100 ) >> >> >> >> > i would like to create a xml with all Libraries, but books with >> >> >> > pages more >> >> >> > than 100) >> >> >> >> Just put the conditions in the Library.find call, ie ["books.pages >= >> >> >> ?", 100] or similar. Or better still provide a named scope in Library >> >> >> to do this. >> >> >> >> Colin > > > --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. To post to this group, send email to [email protected] To unsubscribe from this group, send email to [email protected] For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en -~----------~----~----~----~------~----~------~--~---

