I am new to ruby and rails. I have good experience in C/C++ in other
areas of software. But first time trying hands on Ecommerce site.
Can anybody let me know how much time it may take me to do first
ecommerce site in ruby on rails. Its simply to sell 5 products. I don’t
knwo ABC of ruby and rails yet.
It might seem to be stupid question but I seriosuly want to know time
it will take before getting into it as I have Three Months.
It will be great if you can point me to resources/books I can go
through for quick start.
Well if you have three solid months to dedicate you could probably get
pretty close to a finished product. Especially if you understand
programming in general. Rails is powerful, but the power lies in Ruby
and extending things on your own.
I would recommend the following books:
Agile Web D. with Rails 2nd Edition (pragprog.com) - this is
your reference manual, but the step by step tutorial is around an
online book store. The basics, but gives you a good idea.
Then I would try Beginning Ruby on Rails E-Commerce
(http://apress.com/book/bookDisplay.html?bID=10178) - this is slightly
more difficult to follow. I found some points in the book where the
code in the example had changed without them telling me to change it,
and I’d have to jump to the downloadable code for that chapter. This
dives in a bit more into the specifics of ecommerce and also is written
from a test-driven development point of view.
Then I would try Beginning Ruby on Rails E-Commerce
(http://apress.com/book/bookDisplay.html?bID=10178) - this is slightly
more difficult to follow. I found some points in the book where the
code in the example had changed without them telling me to change it,
and I’d have to jump to the downloadable code for that chapter. This
dives in a bit more into the specifics of ecommerce and also is written
from a test-driven development point of view.
I’ve found also some little problem, the first is that they wrote this:
On Dec 31, 2006, at 4:21 AM, nick wrote:
Actually, just let Rails do the work:
def show @book = Book.find(params[:id]) @page_title = @book.title
end
Rails will raise the RecordNotFound exception, which by default is
handled by rendering the 404 page.
Yeah, also…but i think that the 404 page is horrible
so if you have to redirect to a better page which inform you that there
isn’t any product with that id, i think I’ll use the 2nd and not the 1st
code.
Another thing that I’ve found horrible about the book is that they save
the cart+items in the database for each user (with a before filter in
the catalog), they’re crazy (with a really lot of people that see the
site there’s a query for each plus for each item (add/remove)…i think
it’s better the solution on agile web with rails, they use just an
instance variable for the cart and not a database)
Another thing that I’ve found horrible about the book is that they
save the cart+items in the database for each user (with a before
filter in the catalog), they’re crazy (with a really lot of people
that see the site there’s a query for each plus for each item (add/
remove)…i think it’s better the solution on agile web with rails,
they use just an instance variable for the cart and not a database)
Well, to be fair… you have to store the cart somewhere. In AWDwR,
I store the cart in the session, just because I want to illustrate
how to do that. But session data is still persisted between requests,
typically in the database in a production application. So there’s
still a database access on each incoming request to fetch this
session data.
Well, to be fair… you have to store the cart somewhere. In AWDwR,
I store the cart in the session, just because I want to illustrate
how to do that. But session data is still persisted between requests,
typically in the database in a production application. So there’s
still a database access on each incoming request to fetch this
session data.
Dave
i thought that the session data was stored in the pc ram and not
directly in a database
Well, to be fair… you have to store the cart somewhere. In AWDwR,
I store the cart in the session, just because I want to illustrate
how to do that. But session data is still persisted between requests,
typically in the database in a production application. So there’s
still a database access on each incoming request to fetch this
session data.
Dave
i thought that the session data was stored in the pc ram and not
directly in a database
There is an option to store sessions in memory, but it’s generally a
bad idea. In particular, it limits you to running just one
application process, and you lose session data if you restart that
process.
There is an option to store sessions in memory, but it’s generally a
bad idea. In particular, it limits you to running just one
application process, and you lose session data if you restart that
process.
Dave
Ok, thanks…now I’ve to remember that every access to session is a
query to the db…
Ok, thanks…now I’ve to remember that every access to session is a
query to the db…
No, that’s not the case.
At the start of the processing of a request, if that request contains
a session key, then session data corresponding to that key will be
read from the database. At most one database read per incoming
request will occur to load up session data. These will be a
corresponding write to save the session data away at the end of
request processing. (All this assumes you’re using the database to
store session information.)
This generally isn’t something to worry about: it just happens. If
you get to the point where these two database accesses are a
bottleneck (and you’d probably have to have a seriously heavily used
application for this to be the case) then you can switch session
storage strategies very easily.
they use just an instance variable for the cart and not a database)
Of course you can redefine the handling of the RecordNotFound
exception per controller, so you could have a custom 404 message for
products not being found and still use the short method I suggested.
At the start of the processing of a request, if that request contains
a session key, then session data corresponding to that key will be
read from the database. At most one database read per incoming
request will occur to load up session data. These will be a
corresponding write to save the session data away at the end of
request processing. (All this assumes you’re using the database to
store session information.)
This generally isn’t something to worry about: it just happens. If
you get to the point where these two database accesses are a
bottleneck (and you’d probably have to have a seriously heavily used
application for this to be the case) then you can switch session
storage strategies very easily.
Regards
Dave T.
clear
now 2 more queries it’s acceptable, and i think also in the future
thanks
This forum is not affiliated to the Ruby language, Ruby on Rails framework, nor any Ruby applications discussed here.