繁体   English   中英

Ruby / Rails - 如何验证小数位?

[英]Ruby/Rails - How can you validate against decimal scale?

如何验证小数的比例? 例如,假设我们想要存储小数点后最多2个小数点的酒店的评级。 4.34。 3.76。 等等

我已经在线阅读了sqlite with truncate,它基于你与列绑定的精度/比例。 因此,如果你有一个精度3,比例2,并输入1.34567 1.35将被存储。

但是,我正在使用postgres而事实并非如此。 我输入了这个,尽管我的精确度为3,但数据库以某种方式存储了全部内容。

t.decimal :my_column, precision: 3, scale: 2

那么,我如何验证这种事情,为什么postgres存储超过2个小数点开始?

小数位数仅在值为字符串时才有意义。 一旦你将它转换为数字,它就会有很多小数,零或更多。

因此,进行此验证的时间是输入(当它是一个字符串时,因为来自用户的所有输入始终是一个字符串)然后在输出上强制执行正确的显示,当它再次是一个字符串时。 在所有其他时间,您不应该担心小数的数量。

就Rails而言,您可以使用访问器方法为您进行一些验证:

def my_column=(value)
  if value[/\A\d+\.\d\d\z/]
    write_attribute :my_column, value
  else
    errors.add(:my_column, :invalid) 
  end
end

您不能使用传统的验证器,因为字符串 - >十进制转换将在验证程序运行之前发生。

一种简单的方法是将等级乘以100并将其存储为整数。 然后你的验证应该是微不足道的。

暂无
暂无

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

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