Skip to Content
Enterprise Rails
book

Enterprise Rails

by Dan Chak
October 2008
Intermediate to advanced
352 pages
10h 30m
English
O'Reilly Media, Inc.
Content preview from Enterprise Rails

Considerations

Although views are often thought of as “just-in-time” tables, and from Rails’s perspective when creating models, we can treat views just like tables, views are not tables. I began this section stating that a view should be thought of as a named subquery. Let’s take a very simple example and imagine that we defined a view, view_of_movies, which is essentially the same as the movies table itself:

create view view_of_movies as
select * from movies;

The view name, view_of_movies, is now a name for the subquery select * from movies;. If we wanted to do a simple select of all the records in this view, the query would look like this:

select *
  from view_of_movies;

But if we expand to show the subquery, we’re actually doing this:

select *
  from (select *
          from movies);

Now it should become clear that many standard table operations won’t work with views. Some operations that won’t work on views include:

  • Inserting

  • Deleting

  • Updating

  • Referencing from another table

  • Adding constraints

  • Indexing

Although this seems like a long list of things you can’t do, and it is, that’s actually OK. These aren’t disadvantages of views; they’re just not what views are meant for. The word “view” itself implies that they are for looking at, not for modifying.[4]

Let’s examine each of these constraints in turn and see what it means for our Rails application.

Insert, Update, Delete

Attempting to insert, update, or delete on a view triggers a database error. When you need to write data, you must do it against table-backed ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.

Read now

Unlock full access

More than 5,000 organizations count on O’Reilly

AirBnbBlueOriginElectronic ArtsHomeDepotNasdaqRakutenTata Consultancy Services

QuotationMarkO’Reilly covers everything we've got, with content to help us build a world-class technology community, upgrade the capabilities and competencies of our teams, and improve overall team performance as well as their engagement.
Julian F.
Head of Cybersecurity
QuotationMarkI wanted to learn C and C++, but it didn't click for me until I picked up an O'Reilly book. When I went on the O’Reilly platform, I was astonished to find all the books there, plus live events and sandboxes so you could play around with the technology.
Addison B.
Field Engineer
QuotationMarkI’ve been on the O’Reilly platform for more than eight years. I use a couple of learning platforms, but I'm on O'Reilly more than anybody else. When you're there, you start learning. I'm never disappointed.
Amir M.
Data Platform Tech Lead
QuotationMarkI'm always learning. So when I got on to O'Reilly, I was like a kid in a candy store. There are playlists. There are answers. There's on-demand training. It's worth its weight in gold, in terms of what it allows me to do.
Mark W.
Embedded Software Engineer

You might also like

Advanced Rails

Advanced Rails

Brad Ediger
Rails Crash Course

Rails Crash Course

Anthony Lewis
Ajax on Rails

Ajax on Rails

Scott Raymond

Publisher Resources

ISBN: 9780596515201Errata Page