ruby-on-rails – Rails PostgreSQL按字符串的整数值排序

在我的Rails应用程序上开发数据库架构时,我犯了一个战略错误

现在我必须使用价格功能实现排序

MyModel.order('price DESC')

price是数据库中的字符串类型,例如,导致50大于2000

有没有办法在不改变数据库结构的情况下实现这样的.order()?

编辑:

我切换到价格列的正确类型(整数).我花了一个小时才进行重构.

解决方法

使用Postgresql,你需要将你的字符串转换为整数/浮点数/小数(在你决定100%不会去并改变列类型以纠正一个之后):

MyModel.order('price::integer DESC')

考虑一下这个answer,让它快速运行.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...