可以在控制器操作中使用活动记录查询吗?

时间:2018-12-27 17:06:07

标签: activerecord ruby-on-rails-5 advanced-search

我有一个控制器操作,需要从现有数据库中查找数据。我仍在学习Rails,最近才知道有关活动记录查询的信息。 但是我不确定如何在控制器操作中使用它从数据库中获取记录。 有人可以举例说明吗?

预先感谢

2 个答案:

答案 0 :(得分:0)

是的,您可以在控制器内部使用活动记录查询。但是最好只将活动记录查询逻辑放在模型中。因为导轨遵循MVC体系结构

MVC代表模型,视图和控制器。 MVC将应用程序分为三个部分-模型,视图和控制器。

模型:模型代表数据的形状和业务逻辑。它维护应用程序的数据。模型对象检索模型状态并将其存储在数据库中。模型是数据和业务逻辑。

视图:视图是一个用户界面。使用模型向用户查看显示数据,并使他们能够修改数据。

Controller:控制器处理用户请求。通常,用户与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

答案 1 :(得分:0)

我找到了答案。我们可以使用活动记录查询从控制器中的数据库中获取记录。示例如下:

请考虑具有颜色属性的数据库“ Dress”。现在,我要获取所有具有橙色的“连衣裙”。因此查询将为:

@dresses = Dress.where(color: 'orange')

这将获取所有颜色=橙色的礼服的记录。