避免 Rails 将 PostgreSQL inet 类型转换为 IPAddr 对象?

use*_*706 6 ruby postgresql ruby-on-rails inet ruby-on-rails-4

我的 Rails 项目有问题。在以前的项目(不是 Rails)中,我只是使用 PostgreSQL 中的“inet”类型来存储带有子网的 IP 地址,如下所示:

 192.168.1.0/30 
 192.168.1.1/30
 192.168.1.2/30
 192.168.1.3/30
Run Code Online (Sandbox Code Playgroud)

这是将 IP 和子网存储在一个字段中的好方法。现在我在 Rails (4.0.1) 和 Ruby (2.0.0 p247) 中使用 inet 类型,但是当我阅读和尝试时,Rails 将它转换为 IPAddr 对象。但是这个 IPAddr 对象正在破坏我的格式。它将上面的四个示例转换为以下内容:

 192.168.1.0/30
Run Code Online (Sandbox Code Playgroud)

有没有办法阻止 Rails 这样做,或者有没有办法用字符串代替它?或者也许是另一个宝石?

当我尝试存储某些内容时,甚至当我尝试从数据库中读取现有值时,都会出现问题。

只是为了更细化:

 IPAddr.new("192.168.1.2/255.255.255.252") 
Run Code Online (Sandbox Code Playgroud)

创建数据库条目:

 192.168.1.0/24
Run Code Online (Sandbox Code Playgroud)

the*_*Man 4

如果我没记错的话,192.168.1.0/30技术上是正确的。

以下是一些可能有帮助的事情:

  • 除了 IPAddr 之外,用于处理 IPv4 和 IPv6 的一个非常好的 gem 是IPAddress。如果 Active Record 已将值传递给 IPAddr,并且它已更改该值,则不会有太大帮助,因此您需要告诉 Active Record 使用 IPAddress。
  • 如果您打算使用 PostgreSQL 通过其内置 IP 函数来处理子网划分需求,那么将您的地址存储为 PostgreSQL“inet”类型就可以了。正如您所发现的,如果您只想存储 IP 地址并检索它,那么这是一个坏主意。Active Record 尝试遵循字段类型,并将其映射到最接近的 Ruby 类,即 IPAddr。相反,我总是将 IP 存储为字符串(以便以我想要的形式快速检索)和适当大小的整数,以便我可以以二进制方式执行所有子网划分操作和匹配。

    如果在查询中告诉 PostgreSQL 在将值返回到 Active Record 之前将其转换为字符串,这可能会有所帮助。此时,您可以在解析后使用 IPAddress 来处理该值。如何告诉 Active Record 告诉 PostgreSQL 这样做是一个不同的问题。

  • 只是好奇你如何告诉活动记录使用 IPAddress (3认同)