Creating and Updating
Learn to create and update new and existing rows using active record
We'll cover the following
Names such as SQLite and MySQL emphasize that all access to a database is via the Structured Query Language (SQL). In most cases, Rails will take care of this for us, but that is completely at our discretion. As we’ll see, we can provide clauses or even entire SQL statements for the database to execute.
If we’re familiar with SQL already, take note of how Rails provides places for familiar clauses such as select
, from
, where
, group by
, and so on as you read this section. If we’re not already familiar with SQL, one of the strengths of Rails is that we can defer learning more about such things until we actually need to access the database at this level.
In this section, we’ll continue to work with the Order
model from the Depot application as an example. We’ll be using Active Record methods to apply the four basic database operations: create
, read
, update
, and delete
.
Creating new rows
Given that Rails represents tables as classes and rows as objects, it follows that we create rows in a table by creating new objects of the appropriate class. We can create new objects representing rows in our orders
table by calling Order.new()
in line 1. We can then fill in the values of the attributes, which correspond to columns in the database. Finally, we call the object’s save()
method in line 6 to store the order back into the database. Without this call, the order would exist only in our local memory.
Get hands-on with 1300+ tech skills courses.