可以在控制器操作中使用活动记录查询吗?
Can active record queries be used in controller action?
我有一个需要从现有数据库中查找数据的控制器操作。我仍在学习 rails 并且最近开始了解活动记录查询。
但我不确定如何使用它在控制器操作中从数据库中获取记录。
任何人都可以用一些例子来解释这个吗?
提前致谢
是的,您可以在控制器内使用活动记录查询。但最好只将活动记录查询逻辑放在模型中。因为rails遵循MVC架构
MVC 代表模型、视图和控制器。 MVC 将应用程序分为三个组件 - 模型、视图和控制器。
模型:模型表示数据和业务逻辑的形状。它维护应用程序的数据。模型对象检索模型状态并将其存储在数据库中。模型是数据和业务逻辑。
视图:视图是一个用户界面。使用模型向用户查看显示数据并允许他们修改数据。
控制器:控制器处理用户请求。通常,用户与 View 交互,View 又会引发适当的 URL 请求,该请求将由控制器处理。控制器使用模型数据作为响应呈现适当的视图。
示例:-
class RoomsController < ApplicationController
before_action :set_room, only: [:show, :edit, :update, :destroy]
# GET /rooms
# GET /rooms.json
def index
@rooms = Room.all
end
# GET /rooms/1
# GET /rooms/1.json
def show
end
# GET /rooms/new
def new
@room = Room.new
end
# GET /rooms/1/edit
def edit
end
# POST /rooms
# POST /rooms.json
def create
@room = Room.new(room_params)
respond_to do |format|
if @room.save
format.html { redirect_to @room, notice: 'Room was successfully created.' }
format.json { render :show, status: :created, location: @room }
else
format.html { render :new }
format.json { render json: @room.errors, status: :unprocessable_entity }
end
end
end
# PATCH/PUT /rooms/1
# PATCH/PUT /rooms/1.json
def update
respond_to do |format|
if @room.update(room_params)
format.html { redirect_to @room, notice: 'Room was successfully updated.' }
format.json { render :show, status: :ok, location: @room }
else
format.html { render :edit }
format.json { render json: @room.errors, status: :unprocessable_entity }
end
end
end
# DELETE /rooms/1
# DELETE /rooms/1.json
def destroy
@room.destroy
respond_to do |format|
format.html { redirect_to rooms_url, notice: 'Room was successfully destroyed.' }
format.json { head :no_content }
end
end
private
# Use callbacks to share common setup or constraints between actions.
def set_room
@room = Room.find(params[:id])
end
# Never trust parameters from the scary internet, only allow the white list through.
def room_params
params.require(:room).permit(:name, :type, :user_id)
end
end
我找到了答案。我们可以使用活动记录查询从控制器中的数据库中获取记录。例子如下:
考虑一个具有颜色属性的数据库'Dress'。现在我想获取所有具有橙色的 'dresses' 。所以查询将是:
@dresses = Dress.where(color: 'orange')
这将获取所有颜色为橙色的连衣裙的记录。
我有一个需要从现有数据库中查找数据的控制器操作。我仍在学习 rails 并且最近开始了解活动记录查询。 但我不确定如何使用它在控制器操作中从数据库中获取记录。 任何人都可以用一些例子来解释这个吗?
提前致谢
是的,您可以在控制器内使用活动记录查询。但最好只将活动记录查询逻辑放在模型中。因为rails遵循MVC架构
MVC 代表模型、视图和控制器。 MVC 将应用程序分为三个组件 - 模型、视图和控制器。
模型:模型表示数据和业务逻辑的形状。它维护应用程序的数据。模型对象检索模型状态并将其存储在数据库中。模型是数据和业务逻辑。
视图:视图是一个用户界面。使用模型向用户查看显示数据并允许他们修改数据。
控制器:控制器处理用户请求。通常,用户与 View 交互,View 又会引发适当的 URL 请求,该请求将由控制器处理。控制器使用模型数据作为响应呈现适当的视图。
示例:-
class RoomsController < ApplicationController
before_action :set_room, only: [:show, :edit, :update, :destroy]
# GET /rooms
# GET /rooms.json
def index
@rooms = Room.all
end
# GET /rooms/1
# GET /rooms/1.json
def show
end
# GET /rooms/new
def new
@room = Room.new
end
# GET /rooms/1/edit
def edit
end
# POST /rooms
# POST /rooms.json
def create
@room = Room.new(room_params)
respond_to do |format|
if @room.save
format.html { redirect_to @room, notice: 'Room was successfully created.' }
format.json { render :show, status: :created, location: @room }
else
format.html { render :new }
format.json { render json: @room.errors, status: :unprocessable_entity }
end
end
end
# PATCH/PUT /rooms/1
# PATCH/PUT /rooms/1.json
def update
respond_to do |format|
if @room.update(room_params)
format.html { redirect_to @room, notice: 'Room was successfully updated.' }
format.json { render :show, status: :ok, location: @room }
else
format.html { render :edit }
format.json { render json: @room.errors, status: :unprocessable_entity }
end
end
end
# DELETE /rooms/1
# DELETE /rooms/1.json
def destroy
@room.destroy
respond_to do |format|
format.html { redirect_to rooms_url, notice: 'Room was successfully destroyed.' }
format.json { head :no_content }
end
end
private
# Use callbacks to share common setup or constraints between actions.
def set_room
@room = Room.find(params[:id])
end
# Never trust parameters from the scary internet, only allow the white list through.
def room_params
params.require(:room).permit(:name, :type, :user_id)
end
end
我找到了答案。我们可以使用活动记录查询从控制器中的数据库中获取记录。例子如下:
考虑一个具有颜色属性的数据库'Dress'。现在我想获取所有具有橙色的 'dresses' 。所以查询将是:
@dresses = Dress.where(color: 'orange')
这将获取所有颜色为橙色的连衣裙的记录。