首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在sinatra中处理数据库错误

在sinatra中处理数据库错误
EN

Stack Overflow用户
提问于 2019-05-30 19:09:49
回答 1查看 69关注 0票数 0

我正在编写一个带有活动记录的Sinatra http-server。我正在使用pg数据库来存储数据。

在这段代码中,我想要从数据库中获得所有的汽车参数(名称,给他们订单,限制他们),我需要处理来自数据库的错误。

例如,如果我从curl ping‘/car’:

代码语言:javascript
运行
复制
curl -X GET http://localhost:8080/cars?attribute=error

我需要结果:“对不起,没有名称错误的属性”。

代码语言:javascript
运行
复制
get '/cars' do    
  @cars = Car.order("#{params[:attribute]} #{params[:order]}").limit(params[:limit]).offset(params[:offset])
  @cars.to_json
 end

如何处理来自数据库的异常并将其显示给用户?

EN

Stack Overflow用户

发布于 2019-05-31 10:54:44

您需要检查传入的属性参数

代码语言:javascript
运行
复制
get '/cars' do   
  if Car.columns.map(&:name).include?(params[:attribute]) 
    @cars = Car.order("#{params[:attribute]} #{params[:order]}")
             .limit(params[:limit]).offset(params[:offset])
    @cars.to_json
  else
    { error: 'Sorry, but there is no attribute with name error' }.to_json
  end
end
票数 0
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56377121

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档