gpt4 book ai didi

ruby-on-rails - 在 Rails 和 PostgreSQL 中用于 Facebook 用户 ID 的数据类型

转载 作者:行者123 更新时间:2023-11-29 11:54:37 25 4
gpt4 key购买 nike

我有一个用于 Rails 应用程序的 PostgreSQL 数据库。

我想存储 Facebook 用户 ID,所以我想我可以使用整数,但它不够大,所以我选择了 float 。

但是现在 Rails 将 .0 添加到我的用户 ID 的末尾

我可以使用什么数据类型,这样对于很长的 Facebook 用户 ID 就不会发生这种情况 example: 100002496803785

最佳答案

您可以在整数列上使用 :limit => 8 来获得 bigint。例如:

class Pancakes < ActiveRecord::Migration
def change
create_table :pancakes do |t|
t.integer :c, :limit => 8
end
end
end

然后,从psql:

=> \d pancakes
Table "public.pancakes"
Column | Type | Modifiers
--------+---------+-------------------------------------------------------
id | integer | not null default nextval('pancakes_id_seq'::regclass)
c | bigint | not null
Indexes:
"pancakes_pkey" PRIMARY KEY, btree (id)

还有你的 eight byte bigint专栏。

您还可以使用字符串作为 Facebook ID。您没有对 ID 进行任何算术运算,因此它们实际上只是不透明的比特包,恰好看起来像大整数,字符串会很好地排序和比较,因此它们可能是最佳选择。由于字符串的大小增加超过整数,将会有一些存储和访问开销,但这可能不足以产生任何明显的差异。

切勿将 double 用于需要精确的内容。在这种情况下你可能没问题(当然除了尾随的 .0 )因为你有 52 位的尾数,这意味着 double 会起作用就像一个 52 位整数,直到您的值大到需要指数为止。即便如此,为此使用 double 将是一个糟糕的想法,也是对类型系统的滥用。

关于ruby-on-rails - 在 Rails 和 PostgreSQL 中用于 Facebook 用户 ID 的数据类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8503042/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com