我必须在rails中制作一个API,用特定的过滤器查询数据库。问题是大约有9-10列,我不能去查询每一个组合。我对此非常陌生,在python/django中,我过去常常通过创建一个dict = {"param": "query_condition"}并将其作为objects = SomeModel.objects.filter(**dict)进行传递来实现它。当我不知道我会从前端收到多少个参数时,我怎么能在我的rails api中做到这一点。目前我的控制器看起来像这样的class CharactersController < ApplicationController
def index
@status = 200
@message = ""
@page = (params[:page].blank? ? 1 : params[:page].to_i)
@results = Building.all
@total = Building.count
end
def get_residents_with_characters(params)
@item = Resident.where()`基本上是一些用于在get_residents_with_characters中查询的类似python的语法。
发布于 2019-11-16 15:49:03
有很多方法可以实现你想要的;我通常会使用过滤器来减少模型:
params = {"foo" => "bar", "baz" => "boo"}
query =
params.reduce(Resident) do |q, (k, v)|
q.where(k.to_sym => v)
end可能需要进行一些卫生处理等。
https://stackoverflow.com/questions/58888622
复制相似问题