On Jun 7, 2009, at 2:28 PM, doug wrote:
> Embarrassingly, I must admit that I have never understood models. I
> am hoping that with this post I can clear up a basic question that
> will allow me to get a toe-hold into understanding models. The basic
> question is this:
>
> Do we only use models with databases or do they have other uses?
Models let you encapsulate business logic.
> Models descend from ActiveRecord::Base. That certainly gives rise to
> a notion that models are used exclusively with databases. However, I
> have read plenty of chatter encouraging me to move code out of the
> controller and into the model.
Not always. For example, I have a project with a SearchResult model;
it doesn't correspond directly to a table, but it does leverage
several other models (7, I think) that do persist data in the database.
> At the moment, I happen to be dealing with a perfect example. In a
> user's profile I store an integer named 'flags'. The integer is a
> decimal representation of a set of binary flags that correspond to
> various yes/no configuration selections that the user has made. I
> have written a very short method that will accept 2 arguments, a
> user's flags integer and the weight of a specific flag. The method
> returns true or false depending on whether the specific flag is set in
> the given flags integer. The method has absolutely nothing to do with
> a database. The question is: Where do I put this method? From the
> description that I have given I think that it is clear that this
> method is back-room, heavy-duty, number-crunching stuff (to use terms
> that I have seen in my reading). So, does it go in the model? If so,
> how do I access it from other places?
>
> Thanks very much for any input.
>
> ... doug
So you're modeling a set of boolean flags, huh? Do you know about the
Integer#[] method?
irb> 3.downto(0) {|i| puts "10[#{i}]==#{10[i]}"}
10[3]==1
10[2]==0
10[1]==1
10[0]==0
=> 3
irb> 10.to_s(2)
=> "1010"
The point is that this method has everything to do with the *data*. It
is probably true that the data is persisted in the database, but this
method would make sense even if you kept the data in an Array, yes?
Put the method into the User model. Since you didn't give enough
specifics, I'll base an example on somewhat of a tangent since you
mentioned "back-room".
class User
def liberal?
self.flags[0].nonzero?
end
def moderate?
self.flags[1].nonzero?
end
def conservative?
self.flags[2].nonzero?
end
end
Instead of asking political_leaning(doug.flags, User::Moderate) you
can just say doug.moderate? and be done. You could define constants
for the bit/flag numbers, too.
If this doesn't help you see how to use a model, post some code and
you might get a different style of answer.
-Rob
Rob Biedenharn http://agileconsultingllc.com
[email protected]
--~--~---------~--~----~------------~-------~--~----~
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
-~----------~----~----~----~------~----~------~--~---