好吧再次忘记我在Rails中的noobiness,但我也没有找到它.虽然我认为这可能是因为它...它不存在?
好的,所以我还在玩RoR,我为员工添加了一个控制器,非常简单,只需要一个名字,clock_no和工资.但是,如果我不想通过ID搜索员工呢?对我而言,用户按时钟编号搜索会更容易,但我不知道它是如何工作的.我假设它与此行有关,更具体地说是set_employee行:
private
# Use callbacks to share common setup or constraints between actions.
def set_employee
@employee = Employee.find(params[:id])
end
# Never trust parameters from the scary internet, only allow the white list through.
def employee_params
params.require(:employee).permit(:name, :clock_no, :wage)
end
Run Code Online (Sandbox Code Playgroud)
但是我可能会离开.
好的,所以我的解决方案最终只是改变模型中的primary_key:
self.primary_key = 'clock_no'
Run Code Online (Sandbox Code Playgroud)
并将返回设置为json:
def show
@employee = Employee.find(params[:id])
respond_to do |format|
format.html
format.json { render json: @employee }
end
end
Run Code Online (Sandbox Code Playgroud)
但是,我不认为这真的是最终所有的解决方案,再次我的高傲可能会显示,但它似乎有点像我.如果您想通过说出名称或其他不是主键并且无法像我的情况那样更改主键的内容进行搜索,我的举动将是什么? 鼻子回到文档
fiv*_*git 16
用途where:
Employee.where(clock_no: params[:clock_no])
Run Code Online (Sandbox Code Playgroud)
where返回一个ActiveRecord关系,所以如果你需要第一个(并且可能只有clock_no是唯一的实例),请使用first,如下所示:
Employee.where(clock_no: params[:clock_no]).first
Run Code Online (Sandbox Code Playgroud)
这将只执行一个SQL查询以获得第一个Employee匹配clock_no.
曾经有魔术探测器find_by_clock_no,但是从Rails 4开始就被弃用了,我假设你正在使用它们.
有关ActiveRecord查询的更多信息,另请参阅Rails文档.
| 归档时间: |
|
| 查看次数: |
14174 次 |
| 最近记录: |