Okay...

So to do this, you need to understand meta-programming to a degree because 
that's what you're doing.

In normal Rails, you'd create a model as part of the development process, but 
what you're doing is creating some code that creates models itself (ie one 
level of abstraction higher than normal).

The equivalent straight ruby comparison is: (compare 1, with 2, below):

1. Creating a class (this is normal programming)

class Cat
  def hi
    puts 'meow'
  end
end

You can then create new Cat objects like this:
furrycat = Cat.new

and make it meow like this:
furrycat.hi

2. Creating a piece of code that creates a class (this is meta-programming)

a_class = Class.new
hi_method_block = Proc.new{ puts 'meow' }
a_class.send(:define_method, :hi, &hi_method_block)

You can then create new "Cat" objects like this:
furrycat = a_class.new

and make it meow like this:
furrycat.hi

---

So...  assuming you followed that, then you'll understand that you could do the 
same thing with ActiveRecord::Base classes, which is what forms the bases for 
Active Record model classes. This is how you'd dynamically LOAD one of your 
programmatically generated models. Creating the table is just a matter of 
executing some arbitrary SQL which can be built using 
ActiveRecord::Base.connection.execute. (Eg to run a count of a fictitious users 
table, you'd do this: ActiveRecord::Base.connection.execute("SELECT COUNT(*) 
FROM users;")

However, like I said, there's no point trying to do this until you can walk, 
because this really is running. Most Rails devs hardly ever get into this 
stuff. I've been a Rails developer since 2005, and I've only done this sort of 
dynamic table and database thing once or twice in practice.

Julian

On 04/04/2013, at 6:43 PM, Johan Vauhkonen <[email protected]> wrote:

> Thanks for posting, I appreciate the feedback.
> 
> I'll start with keeping everything within a single database and take it from 
> there.
> 
> You are right Julian in that I am new with RoR and what I've asked for is 
> advanced.
> 
> I'm still curious though how creating databases dynamically would be done so 
> if it's explained anywhere I'd love to read it!
> 
> 
> 2013/4/4 Julian Leviston <[email protected]>
> 
> On 04/04/2013, at 6:05 PM, Johan Vauhkonen <[email protected]> wrote:
> 
> > Thanks for replying, Julian.
> >
> > Can you point me to any resources that describe how to do it?
> >
> > I agree that I should not optimize prematurely but what I'm considering is 
> > which is easier,
> > to go with dynamically creating databases from the start or to extract data 
> > from the single database to new databases later on?
> >
> > It's at least something to keep in the back of my mind.
> 
> Hi,
> 
> You shouldn't attempt to do this if you don't already understand enough Ruby 
> / Rails to do it yourself.
> 
> So, I suggest sticking with what you *can* do first.
> 
> This might sound like a cop out, but there's very good reason. It's very 
> advanced Rails and you really shouldn't attempt something like this until you 
> understand the basics really well IMHO.
> 
> Julian
> 
> --
> You received this message because you are subscribed to a topic in the Google 
> Groups "Ruby on Rails: Talk" group.
> To unsubscribe from this topic, visit 
> https://groups.google.com/d/topic/rubyonrails-talk/S73DxPeqvy4/unsubscribe?hl=en-US.
> To unsubscribe from this group and all its topics, send an email to 
> [email protected].
> To post to this group, send email to [email protected].
> For more options, visit https://groups.google.com/groups/opt_out.
> 
> 
> 
> 
> -- 
> You received this message because you are subscribed to the Google Groups 
> "Ruby on Rails: Talk" group.
> To unsubscribe from this group and stop receiving emails from it, send an 
> email to [email protected].
> To post to this group, send email to [email protected].
> For more options, visit https://groups.google.com/groups/opt_out.
>  
>  

-- 
You received this message because you are subscribed to the Google Groups "Ruby 
on Rails: Talk" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To post to this group, send email to [email protected].
For more options, visit https://groups.google.com/groups/opt_out.


Reply via email to