Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/variables/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ruby on rails 如何定义用于动态列的数据类型?_Ruby On Rails_Ruby On Rails 3.1 - Fatal编程技术网

Ruby on rails 如何定义用于动态列的数据类型?

Ruby on rails 如何定义用于动态列的数据类型?,ruby-on-rails,ruby-on-rails-3.1,Ruby On Rails,Ruby On Rails 3.1,对于普通数据库列,Rails会根据列类型自动选择匹配的Ruby数据类型,即decimal/integer/varchar列最终是BigDecimal/Fixnum/String属性 但是如果我使用计算列查询数据库 Model.select(['models.*', 'calculated_int_column']).other_arel_stuff 属性computed_int_列始终包含字符串对象,即使我在select语句中使用显式转换为整数 我猜这是因为Rails使用模式查找列类型 我如何

对于普通数据库列,Rails会根据列类型自动选择匹配的Ruby数据类型,即decimal/integer/varchar列最终是BigDecimal/Fixnum/String属性

但是如果我使用计算列查询数据库

Model.select(['models.*', 'calculated_int_column']).other_arel_stuff
属性computed_int_列始终包含字符串对象,即使我在select语句中使用显式转换为整数

我猜这是因为Rails使用模式查找列类型

我如何告诉Rails本专栏使用哪种Ruby类型


提前谢谢。

不确定这是否是您想要的答案,但您可以覆盖getter方法以返回整数:

class Model
  def calculated_int_column
    @calculated_int_column = 0 if @calculated_int_column.nil?
    @calculated_int_column.to_i
  end
end

我宁愿选择@calculated_int_column.to_I,除非@calculated_int_column.nil?但除此之外,我希望有一个更一般的解决方案,因为我有许多计算属性。虽然未来的缓存功能可能会减少它们是的,但我不确定返回的nil值是否会破坏您的应用程序,我只是把第一行放在以防万一。