繁体   English   中英

语法错误,意外的 tCONSTANT,期待 ')'

[英]syntax error, unexpected tCONSTANT, expecting ')'

我写了一个方法,我收到一个错误。 这是我的代码:

def workouts_number
  @workout_block = BlockWorkout.all
  @number = Hash.new(0)

  @workout_block.each do |record|
    @current_workout_block = BlockWorkout.group(:workout_id).order(COUNT(workout_id) DESC).limit(5)
    @name = @current_workout_block['block_name']
    @number[@name] += 1
  end

  render :json => {data: {unprocessed: @workout_block, processed: @number}}
end

然后我收到了这个错误信息:

{
  "status": 500,
  "error": "Internal Server Error",
  "exception": "#<SyntaxError: /home/gabriel_rc/Área de Trabalho/Atlas/atlas-academia-back/app/controllers/workouts_controller.rb:146: syntax error, unexpected tCONSTANT, expecting ')'\n...d).order(COUNT(workout_id) DESC).limit(5)\n...                           ^~~~\n/home/gabriel_rc/Área de Trabalho/Atlas/atlas-academia-back/app/controllers/workouts_controller.rb:174: syntax error, unexpected end, expecting end-of-input>",
  "traces": {
    "Application Trace": [
      {
        "exception_object_id": 27087800,
        "id": 0,
        "trace": "app/controllers/workouts_controller.rb:146: syntax error, unexpected tCONSTANT, expecting ')'"
      },

它说在第 146 行发生了语法错误。第 146 行如下:

@current_workout_block = BlockWorkout.group(:workout_id).order(COUNT(workout_id) DESC).limit(5)

我怎么解决这个问题?

只需在 SQL 代码段周围添加引号,以便由 Ruby 将其作为字符串处理。

@current_workout_block = BlockWorkout.group(:workout_id).order("COUNT(workout_id) DESC").limit(5)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM