- user should be renamed as "old_users"
- create a new table "user"
- restore the data with different column names in the "user"
Wednesday, December 31
Qucik Fix: ActiveRecord Migrations reset_column_information
Quick Fix: YAML syntax & Fixtures issue
having looked into the fixture, it was pretty clear that this is about right syntax. And this was the quick fix which worked out:
Tuesday, December 30
Usability Tip: Ajax loading/busy indicator
well it's done.
Thursday, December 18
Tweak: updating ruby gems
- gem install rubygems-update
- update_rubygems
Monday, December 8
Range Class in Ruby
x..y: includes the end values
(1..5).each do n
puts n, ' '
end
(1...5).each do n
puts n, ' '
end
In the first literal case, values 1, 2, 3, 4, 5 would be printed. Whereas, in the second litereral case 1, 2, 3, 4 only will be printed.Interestingly methods end/alias would still give the end value of the range. In such case, end_excluded? is apt choice to distinguish.
Wednesday, November 12
Integration Testing: xml_http_request
xml_http_request "/store/add_to_cart" , :id => ruby_book.id
and strangely I was getting syntax error. Seems the book did miss out another parameter which would define the method type. Referring to online documentation, made things clear.
xml_http_request(request_method, path, parameters = nil, headers = nil)
Performs an XMLHttpRequest request with the given parameters, mirroring a request from the Prototype library.
The request_method is :get, :post, :put, :delete or :head; the parameters are nil, a hash, or a url-encoded or multipart string; the headers are a hash. Keys are automatically upcased and prefixed with ‘HTTP_’ if not already.
Saturday, November 8
Ajax even @ home - I am serious
Have a nice weekend :)
Thursday, October 16
SnappyFingers - a new way of learning through FAQ's
Let me put it this way, just search through relevant topic and keep filtering the appropriate website(s). I feel many of us would like to understand a topic with basic and frequently asked questions What? Why? Where? How? Which? Who?
Matching to above criteria and thinking process, I found a new product in the market "relevant answers for your frequent questions" - SnappyFingers. It's a smart explorer that would fetch across the relevant answers for your questions. SnappyFingers made the process of finding answers pretty easier.
Thursday, September 4
My Experiments with Google Chrome - 3
Google's Chrome Terms of Service take out a royalty-free license for Google of any content submitted by users over the internet...
Read it from source... http://tapthehive.s483.sureserver.com/chrome.html
Wednesday, September 3
My experiments with Google Chrome -2
My experiments with Google Chrome -1
profile usage:
I extensively make use of this profile feature. I create multiple profiles, based on my work.
- To create new firefox extension.
- To test the extensions.
- For office work.
- ...
- ...
Though I prefer using stumble to bookmark my favorite pages, for quick reference I store some on Firefox bookmark tool bar. When I tried with chrome, it had imported bookmarks randomly from one of the firefox profiles.
Addon's:
I feel the usability of browser increases with these add-on's, extensions.
Google Chrome
I am always eager about the products that comes out of Google. I am under impression that whatever Google comes out with will have more usability, simplicity, to the point, light weight... and I can go on listing them.
From Google's official blog entry, I went through the story behind building the Google Chrome. It was quite impressive and it shows the approach is really good.
keep watching and experimenting...
Wednesday, August 27
RoR course: RSS Maker/Parser
I would like to share the details of how Ruby supports to generate and read the RSS. Before going into details, let us look into few basics of what we are going to deal with.
Note: An RSS document is often referred as “feed” or “web feed” or “channel”.
What is RSS?
- Really Simple Syndication.
- It is a easy way to share defined content and news/titles/posts from www
- RSS is written in XML
Why use RSS?
RSS can be updated automatically; this enables users to track/monitor their favorite sites, news channels, websites… without even going/visiting the sites. Since it is simple, light and fast-loading this can be used even in PDA’s, mobiles thus ensuring the accessibility even simpler.
Who should use RSS?
RSS is ideal to be used if the source is dynamic. In the sense that would change rapidly for say new sites, micro/web blogs… RSS is not meant for static pages, website that doesn’t have updates frequently.
With so many websites/blogs/calendars… everybody generating the RSS, the reading/grabbing job is taken care by “RSS/feed reader” or “aggregator”. These aggregators can be either desktop based or web based. The user needs to subscribe his favorite site feeds by submitting the RSS link provided by the site to these aggregators and they would send the user the subscribed updates as and when they occur.
Parser:
Parser identifies the feed Url provided and reads the document and we can publish the feed with our own display options. So all that we need is a simple feed url. Let us say we need to publish the feed content of particular site on our blog/site.
Since there are multiple versions of the RSS available based on the version we need to include/require those libraries while parsing the feed.
- A controller that would handle all the feed related actions, includes/refers the required libraries.
- An action/method that would use the rss/parser library to read the feed.
- Extract the necessary elements/content.
- Pass on the elements/content to the views.
require 'open-uri'
require 'rss/0.9'
require 'rss/1.0'
require 'rss/2.0'
require 'rss/parser'
require "rexml/document"
class RssFeedController <>
#This action is used to get the rss feed of the blog mentioned
def parse_feed
url = 'feed url'
rss = RSS::Parser.parse(open(url){|fd|fd.read})
item_rss=rss.items.collect{|item|item.title}
item_link=rss.items.collect{|item|item.link}
@p=item_rss.length
@postfeed=item_rss
@postlink=item_link
@link="url of the link"
return @postfeed,@postlink,@p,@link
end
end
The view part will be a list of articles/content displayed looping over the length of feed.
<%@postlength.times do|i|%>
<li>
<a class="define style" target="_blank" href="<%=@postlink[i]%>">
<%=@postfeed[i]%>
a>
li>
<%end%>
Thus we are done with parsing or reading the existing feed or RSS document.
The view part will be a list of articles/content displayed looping over the length of feed.
Maker:
Maker creates/generates the feed/RSS document of a site/blog. Since there are multiple versions of the RSS available based on the version we need to include/require those libraries while making the feed.
- A controller that would handle all the feed related actions, includes/refers the required libraries.
- An action/method that would use the rss/maker library to read the feed.
- Extract the necessary elements/content.
- Pass on the elements/content to the views (RHTML/RXML).
def generate_feed
version = "2.0"
content = RSS::Maker.make(version) do |m|
m.channel.title = "Title of the post/entry"
m.channel.link = "http://www.linktopost.com"
m.channel.description = "Describe the post"
i = m.items.new_item
i.title = "Ruby to generate RSS feeds"
i.link = "http://www.linktopost.com"
i.description = "Describe the post"
i.date = Time.now
end
end
As you find the above two actions were created for RSS 2.0, hence we have the elements as title, link, description, date… which are as pert RSS 2.0. Based on the version we are referring/using they would change accordingly.
This is a static content based on which we created the feed, to create a dynamic feed say for the posts, articles should iterate over them and pass the info accordingly.
In nutshell, Ruby provides the RSS support with
RSS::Maker.make
RSS::Parser.parse
There are umpteen number of rails plug ins were created and available for rails community that were built on the above mentioned core ruby classes.
Feed Fetcher
Feed Tools
Resource Feeder
Atom Feed helper
…
…
…
This document is prepared as part of Ruby on Rails course that I am writing in blog TechSavvy.
Have something to discuss/suggest/enhance: Reach me tosumanthkrishna (gmail)
References:
http://en.wikipedia.org/wiki/RSS
http://www.w3schools.com/default.asp
Wednesday, July 30
Career Steps: How to tell the world what I am ?
many might be already thinking of implementing/doing few of the mentioned points. But how you do it makes you really different, isn't it!
- Register into relevant/interesting groups/forums & be a watchdog there.
- Actively take part in the technical talks/sessions.
- Try to excel in particular concept and be ready to show your capability. (When u r ready, opportunities sure to come!)
- Keep shouting/discussing at community groups/forums.
- Be attentive and ready to extend your hands to the people with doubts.
- Show you professionalism.
- Start socializing.
- Maintain your personal pages/blogs/websites.
These are just few of the ways that I can immediately think of and I welcome all to suggest more ways if they have any...
Well here comes the action items:
Rails Groups & Forums: (For ruby enthusiasts)
http://www.ruby-forum.com/
http://railsforum.com/
http://groups.google.com/
http://groups.google.com/
http://groups.google.com/
http://www.orkut.com/
http://www.orkut.com/
http://www.orkut.com/
http://groups.google.com/
Professional Network:
http://workingwithrails.com/ (for ror professional)
http://www.linkedin.com
http://www.ecademy.com
Social Networks
http://www.facebook.com
http://www.orkut.com
Personal Page:
http://www.blogger.com
http://www.wordpress.com
http://pages.google.com/
http://myspace.com
Online Knowledge Base:
http://www.scribd.com
http://www.slideshare.net
http://www.slide.com
Bookmarking sites:
www.stumbleupon.com
www.digg.com
www.delicious.com
http://del.icio.us/
Career Steps: Tell what "you" are to the world
- How one I be picked as best from the rest ?
- How can I show that I am different from the rest?
- How can I make it to the top cream?
- How do I know where am I standing in the skill/domain...?
- How do I show my expertise?
- ...
- ...
- ...
Sunday, July 27
Websites -> Weblogs -> Micro Blogging -> ? what next?
Websites:
where you pile up lots and loads of content in form of pages and users/visitors can go through leisurely.
Weblogs (Blogs) :
Later moved to weblogs, popularly known as blogs, for more interactive, updated content.
Micro-blogging:
We are now even ahead of blogs with micro-blogging concept. Users can post limited text about what they are doing?
What caught my attention is how dynamically we are becoming and more dynamically we are able to develop the software tools that can keep up our dynamism, agility, communication, information gathering. So also the market coping up with new trends, millions of websites, later came the revolution through blogs (wordpress, typepad, blogger...) and now the micro-blogging popularised by twitter, jaiku. This micro-blogging became so famous that it influenced well established web applications/products to embed this feature into their own systems.
I observed them in the following places:
LinkedIn, Orkut, Facebook, Digg...
So what next after this micro-blogging?
Are we heading to "nano"???
Thursday, July 17
Scaling of Twitter - What's the truth ?
Twitter used to go down due to the page views load. There is been lot of discussions, questions regarding the scalability of the Twitter. And I too faced many people asking the scalability, capability of the Ruby on Rails (technology with which twitter was built) in building the web applications.
Twitter started as a side project and blew up fast, going from 0 to millions of page views within a few terrifying months. Early design decisions that worked well in the small melted under the crush of new users chirping tweets to all their friends. Web darling Ruby on Rails was fingered early for the scaling problems, but Blaine Cook, Twitter's lead architect, held Ruby blameless:
Hope that clears some air around twitter discussions. Interestingly, there are quite a number of applications that are build around twitter gaining popularity.
For us, it’s really about scaling horizontally - to that end, Rails and Ruby haven’t been stumbling blocks, compared to any other language or framework. The performance boosts associated with a “faster” language would give us a 10-20% improvement, but thanks to architectural changes that Ruby and Rails happily accommodated, Twitter is 10000% faster than it was in January.
twittervision, summize (twitter search) to name few.
Twitter was made very handy with lots useful tools/extensions on every platform that you can think of. From desktop to iphone users, the gadgets are available here.
I too tweet here!
Few slides that comes handy when you want to speak/read, how the scaling of twitter is getting improved.
View/Download From Slideshare.
Scaling-twitter by Blaine
Scaling-twitter @ railsconf-2007
Friday, July 11
Internet Technology Bubble :)
Friday, July 4
Firefox Extensions - Set as Startup Page(s)
A quick fix for this extension. The latest version will have the options set in context menu(i.e, on mouse right click) and under Tools menu options. The button from the status bar is removed now.
Thanks to Prashant for his feedback and I will implement the suggestions in future releases.
Download Extension
We browse umpteen number of sites/pages across the internet everyday. If you like them and you want to keep the selection as startup pages for your browser (FF), you have to change the options manually.
I thought (as most users feel!) it was not convenient and so I ventured to make it as simple extension. Well if you are like me then, "Set as StartUp Pages" is one such simple and profound extension which would let you set the startup pages with a simple button click from your status bar.
How it works?
1. Install the extension.
2. Restart the browser instance.
3. You will find a button "Set Homepage(s)" in statusbar.
Correction:
Button from status bar removed.
Options are visible in Tools menu and context menubar.
4. Browse across pages in as many tabs you want.
5. Click the button to set them as startup pages.
6. An alert message would confirm the above step.
7. Clicking on 'Home' icon, you can see the implementation.
Set As Startup Page(s) - Download
For next release:
1. Option to set the pages just on mouse right click.
2. Help page with instructions.
3. To improvise the alert/confirmation message.
Note: I would like to get your feedback before I submit to Mozilla Add-ons repository.
Set As Startup Page(s) - Download
Wednesday, June 18
Career Steps: Product based company OR Service based company?
Product: an item that ideally satisfies a market's want or need
Service: provision of assistance to customers or clients, products or projects
The product or service is nothing new and it exists in every domain/space across the industry. Let me take up IT as I am into it. Well I started my career with a product based company. From then on I was fortunate to be associated with innovative products, budding products wherever I go.
While I was having a chat with one of my room mates, who worked with few java based projects there arose a little interesting topic, Product based company OR Service based company.
I just raised the same question with Linkedin community to provide their views as follows:
In IT which is good choice to shape a good career is it in Product based company or Service based company? Please give the pro's of each and also con's (if any!)
Following is the response from Rajesh Tibrewala, in which he covered the answers/views of the rest of people who attempted to answer the question.
It varies from person to a person. What i can share with you is how life in one differs from another:
1. Product Based Companies
You spend a lot more time with the same technologies, same code base, and often the same set of features.
You can never know your customer too well - remember, a product is ultimately an attemp to fit the same shoe to feet of all shapes and sizes (but the alternative is the software industry is - people would need to walk barefeet because turnkey projects are too expensive)
If you work on a successful product for a long period of time, the sense of achievement can be tremendous
Seeing a lot of happy customers is thrilling indeed
There are often comparitively long periods of lull - when the product strategy team is trying to figure out the future roadmap, and the latest release is already out
Often you will end up working on a codebase that noone owns - becuase the product is very old, and none of the original code authors are around. Also, the technology the product is based on could be nearing its death
2. Projects
Often developed from scratch - so you start with a clean slate
You get to know your customer very closely
Fast movement across domains, and often technologies
Direct appreciation by the customer
Often more time pressure compared to product cos
Well I selected this as best suit answer (in my view). Please read here for the rest of answers.
My LinkedIn Profile : http://www.linkedin.com/in/sumanthkrishna
Tuesday, June 17
Career Steps: Go by the work and not just by the "BRAND" !
The reason behind the post is, I was at an Engineering college in outskirts of Hyderabad to take a session on Ruby, as part of Open Source talks. Thanks to SWECHA, for giving me the opportunity. Before I started the session I had few questions to the group of 200 odd students so that I can deliver what they are looking for? (Hitting them straight, without wasting my time!).
Interestingly not many of them are aware of any scripting languages, until SWECHA organised series of sessions/talks.
Well during the ruby talk, I did not bug them with usual slides but just directly walked through examples (that kept them awake and attentive through out the session!).
During the Q&A, the usual questions were fired up:
- What is the future for Ruby?
- Can Ruby be used for Desktop and Mobile applications?
- Java vs Ruby?
- Python vs Ruby?
- Who are all implementing/working on Ruby?
Does the company X, Y, Z implementing it?
And then list of few big IT brands started flowing out of them, well I just wondered whether they are looking for the exciting work they will be assigned or just by the "BRAND". Here comes the role of placement officers of the institutes very well to bridge the gap. Occasionally, many groups with industry people visit these colleges to give an exposure and understanding of the industry, current trends, demanding technology/tools...
But what about the colleges that do not get these groups/industry people do not visit?
This is where everyone need play pro-actively in deciding their career based on their interests, knowledge, skills. Students/Freshers should start interacting more with industry people, start gathering/attending to technical/industry forums, discussions and talks.
This kind of socializing will make them understand the reality and they can be prepared for the same and this would help the industry to get skilled people or right attitude people.
As far as I know, Twincling is the one such group with lots of momentum among the student groups, communities, industry that is doing it's role of spreading the awareness. Twincling members are ready to travel length and breadth of Andhra Pradesh (for time being) and conduct workshops for free. Contact the group for more details.
Wednesday, May 7
Extra Money OR Extra Skill !!!
It's been three years (short of few days) in this IT industry. It's been great learning and at every stage and reminds me there is still more to learn.
There was a great temptation in the initial days to look out for extra money options. It's the general feeling that every individual carried on with. It was the time when Blogging culture was spreading very rampant in India and across the world, I got few opportunities to work with Wordpress Blog Engine.
Somehow, the way of the customization, deployment and taking it to live was very very simple(at least I felt) at the same time decent money. From then on I started working towards improvising/gaining more and more knowledge on Blogs. I started marketing myself as Blogger/Blog Expert.
- Marketing a Business/Company/Individual
- Making blog as revenue generator.
- Improvising the Blog/Website traffic.
- SEO (Search Engine Optimization)
- Google AdSense and Adwords.
- RSS Feeds.
- Blog Widgets.
- Rich User Interface.
- Blog making it more user centric.
- ....
- ...
Extra Money:
- You start looking out more options only when you feel/evaluated/decide that this going to be paid later.
- One may find difficult to survive as the competition grows.
- Transition to other technologies/expertise is difficult.
- With gaining knowledge in the back of mind, you explore more and more soon you will discover that you have an edge over others.
- Survival is not the issue as your interest was to gain more knowledge/expertise.
- This is not a transition, but just another skill set.
Coming on to my experience, though I ventured out as an Extra money (though not so successful) option this was really turned out to be an Extra Skill (which I really feel added some flavor to my skill set).
There are more such things which can not be comprised into single post. But I thought to reveal more as series of posts :)
Wednesday, April 9
Build your own OpenSearch/Sherlock engine
I thought of writing a post on creating/building an opensearch engine for your own site, but I just documented for better understanding and made it availble to download/view online.
The document covers the two approaches to create a search client. The code snippet contains the code with sphred as the example site.
View on Scribd:
Download :
Feedback/Suggestions welcome :-)
Thursday, April 3
ActiveRecord - CRUD operations - 2
find
find_by_xyz
find_by_sql
:first :all :conditions :include :order :limit :select :joins :offset :readonly :lock
etc...
Getting into details, previously we created few rows about user into users table. Now we use this find to read/retrieve the data. Little about "find", it is counterpart for "select * from users" in SQL. The syntax is very plain and simple to pick up.
Say, now I want to read/retrieve the data of all users.
User.find(:all)so the find method connects to users table (through User class of model) and through parameter "all" it fetches info of all the users a simple array. If we use parameter :first, then only first record would be fetched.
User.find(:first)say now I want to introduce some constraints. :conditions is the parameter to be used.
Like, I want user with a specific name
User.find(:first,
:conditions => "name='sumanth'" )
but in case the name to be matched comes dynamically through params, then there would be slight change in the above syntax. Like this,
User.find(:first,
:conditions => "name=?,params[:name] ")
or
User.find(:first,
:conditions => "name= '#{params[:name] }'")
if you want more than one parameter to be checked/matched in the conditions then we can separate each with 'and'.
User.find(:first,thus we can play around with more options/parameter that "find" accommodates. Don't forget to separate each options with "," as I had used it after :first and before :conditions options.
:conditions => ["name=? and email=?",params[:name] ,params[:email]])
Wednesday, April 2
ActiveRecord - CRUD operations -1
Create
Read
Update
Delete
Well Rails ActiveRecord does help you out with lots of keywords and many more convenient, easily understandable, meaningful commands. In nut shell, you can carryout all these sql queries without using sql syntax at all...
Inserting data - We generally use SQL Insert statements to insert/create new rows of data and Rails offers a simple way of creating new rows in tables. One of doing it is by using "new" or by "create" method.
The syntax looks very simple, as below:
Based on previous posts we can coolly observe/interpret the above code like this:
- As per ActiveRecord pattern in rails, this says that User is the model connecting to users table in database.
- All the columns (eg:name here...) of the "users" table go in do ... end loop, 'u' is the iterator.
- Once you set the values of each column then end with save (u.save).
Because, new method would only creates an object and so to store into db we need to explicitly say it to save.
Is there any alternative one?
In many instances, people create objects, define the data and they tend to forget saving the data. Active Record offers another method, create, which would instantiates the model object as well as stores it into the database.
Using both new, create methods we can either insert multiple rows of data or even the form data can be passed as parameters.
Wednesday, March 19
ActiveRecord - Connecting to DB and tables
Connecting to databases
Pluralization convention
Relationships between tables
...
Download here
View on Scribd
this would help all to keep in touch before we go deeper on to more Active Record.
more fun awaiting :-)
Thursday, March 13
Firefox Profile Manager
I prefer to use each different profile for the different extensions/add ons that I am working on for Firefox browser and not to mess up these with my default profile which I mail use for browsing and mailing purposes.
For the benefit of first timers, profiles can be created (in Windows) from the run command window
I run teh command
- firefox.exe -P
- firefox.exe -profilemanager
With Minefield (Firefox 3.0*) around we need to start our development/testing even on Minefield apart from regular FF2.0*. Now the same old commands of creating profiles firefox would not work...
Since the minefield is intalled, and being latest the above commands would result in creating profiles in the Minefield but not into the Firefox. There is another command which many might have forgotten:
- "C:\Program Files\Mozilla Firefox\firefox.exe" -profilemanager
- "C:\Program Files\Minefield\firefox.exe" -profilemanager
Thanks to my friend Aruna, whose query had made me dig into Profile Manager of Mozillazine Knowledge base and resulted in writing this post.
ActiveRecord association has_many :through
The above snippet shows a simple example from Josh Susser's blog.
The scenario shows that there are two tables "books" and "contributors" and the a join table "contributions". This is entirely different from habtm, where we had the join table with combination of tables.
And syntactically, we say to each of tables (books, contributors) that they are related to each other through "contributions".
So the join table would have a simple belongs_to and the individual tables will be related with has_many:'table_name' and keyword :through=>'name_of_join_table'
That is with the ActiveRecord relationships. Just to recap
has_and_belongs_to_many
has_many, has_one, belongs_to
We will be slowly moving into other part of rails packages, ActionPack soon.
Sunday, March 9
ROR Workshop -1
Though I am not getting into more details in this post, soon I will be writing/discussing more about them. I thought I would thank one and all in making this workshop pretty informative and very good overall.
Members of Twincling Community
Saifi
Namita
Sumith
My Friends
Rajesh Batta
Hareesh Kumar
My Juniors
Anas
Hafeez
Haritha
Lokesh
Rasheed
Sravanthi
and the great audience. At the end of the day, I felt very very good when few of the attendees asked details about next session.
In fact, I would like to cover few other topics like, Testing in Rails, Exceptional Handling, Migrations & Generators and Plugin integrations ... feel free to comment :-)
Friday, March 7
RoR Workshop @ Hyderabad - Twincling
- to introduce the Ruby on Rails
- MVC Architecture
- ActiveRecord
- ActionController
- ActionView
- ActionMailer
- Pagination
- Ajax
- Rails demo with project
More about the workshop will be updated through the posts, keep watching :-)
Saturday, March 1
has_and_belongs_to_many : habtm in Rails
Let us take this scenario where we have two tables, "products" belong to "categories" and "categories" belongs to "products" in more than one ways. That is each product belongs to many categories and each category contains many products. In each of the model, category and product the relation would be shown using habtm (has_and_belongs_to_many).
Closely observing the above example, we can see that the products table and categories table contains habtm relation. There is an intermediate table "categories_products", which would carry the primary key of each table.
At the database level this is achieved using an intermediate join table. The convention followed here is the name of the join table is the concatenation of the two target table names but in alphabetical order. In our example, we joined the table categories to the table products, so Active Record will look for a join table named categories_products.
Note:
- The join table carry the foreign keys of each table.
- There will be no model for this intermediate table (categories_products)
Well that precisely explains how we implement many to many relationships in Rails. That is not all there is one more way of expressing the relationship between tables, "has_through" which we will touchbase later.
Tuesday, February 26
Ruby on Rails relevance to Startups - @ BarCamp
Many bloggers had already spoken their part about the proceedings through live blogging.
In brief, there was bit chaos on arranging things, running the talks/session parallely, and finally it was more like session with less user participation (devitation from what usual BarCamp famous for!!!)
Sumanth Krishna @ Ruby on Rails Conference |
I wanted to present on my favorite Ruby on Rails and since BarCamp is the place where lot of young minds, entrepreneurs... assemble. So I related it (RoR) to Startups and on "Ruby on Rails relevance to Startup's". I started the session post lunch around 3PM. I did present my views on very well about the startups and when the slides related to Ruby on Rails started, I just carried away more in explaining the details of RoR.
Slides: "RoR relevance to Startups" @ Google sponsored BarCamp5 :)
Scribd
SlidShare
Please feel free to enhance/comment on the presentation.
I am planning for a Workshop on Ruby on Rails with support of Twincling society :-)
Wednesday, February 13
Relationships between tables - How ActiveRecord handles?
- has_one,
- belongs_to,
- has_many,
- has_and_belongs_to_many
- polyphormic
- one-to-one
- one-to-many
- many-to-many
ActiveRecord supports the above mentioned relations and in fact, comes with set of key words which are easy to use, understand and pretty clean.
Let me take few snapshots from David's book:
Note:
- invoices is the table name
- orders is the table name
Now I am into order model, orders having invoices. so the key word that we use here is has_one and then followed by the model name (Note: It is not table name, this is not plural).
has_one :invoice
Next will go to invoice model, since invoices belongs to orders we use the key word belongs_to and then followed by the model name.
belongs_to :order
Well there is not xml written for models, no xml written for relationships. But simple convention and defined keywords done the job for us.
And as you might have guessed the has_many comes into use when the orders table is having relationship with one more table (say, line_items). The below snapshot will help you to understand the syntax and it's usage.
Will look into other keywords and other relationship in the following posts...
Thursday, February 7
Hyderabad hosts BarCamp5
BarCamp what is it?
BarCamp is an international network of user generated conferences — open, participatory workshop-events, whose content is provided by participants — often focusing on early-stage web applications and related open source technologies...
and the u can read more from here...
As part of series of BarCamp, this series is held @ Hyderabad. Into details....
Theme: Social web and beyond
Technologies, demos and startups- betting on Web2.0, Social web, Semantics Web and beyond!
Entrepreneurship
Social Web and Beyond
Opensource and Emerging Technologies
Product/Prototype/Idea Demos
On February 16th, 2008. Saturday
Venue ( Map of the venue )
Block 1, DivyaSree Omega
Survey No. 13, Kondapur Village,
Hyderabad, A.P 500 032
India.
@ Orkut
Spread the word and get the most of it!