0

我对关系数据库中的主键有疑问。假设我有以下表格:

盒子

  • ID
  • 盒子名称

盒子物品

  • ID
  • 项目名
  • belongs_to_box_id(外键)

我们还假设我打算每天存储数百万个项目。我可能会为 BoxItems.Id 使用bigintor guid

我在想什么,我需要你的建议,而不是 BoxItems 的 Bigint Id,使用序列TinyInt号,识别每个项目的是 belongs_to_box_id 加上 tinyint 行的组合(例如 item_numner)。

所以现在我们得到的是:

盒子物品

  • 属于_to_box_id
  • item_sequence_number [TINYINT]
  • 项目名

例子:

Items.Insert(1,1, "my item 1");
Items.Insert(1,2, "my item 2");

因此,我可以使用 tinyint 并节省大量磁盘空间,而不是使用 bigint 或 GUID。

我想知道这种方法的优缺点。我正在使用 MySQL 和 ASP.NET 4.5 开发我的应用程序

4

2 回答 2

0

我建议为这两种方法编写一个简单的测试,比较性能、磁盘空间和实施的难易程度,然后做出判断。您的两个建议都是合理的,我怀疑性能上会有很大差异,但最好的方法是尝试一下,然后您就会确定。

于 2012-10-17T21:26:25.973 回答
0

仔细想想,“盒子/内容”问题和“订单/订单项”问题之间并没有太大区别。

create table boxes (
  box_id integer primary key,
  box_name varchar(35) not null
);

create table boxed_items (
  box_id integer not null references boxes (box_id),
  box_item_num tinyint not null,
  item_name varchar(35) not null
);

对于 MySQL,您可能会使用无符号整数和无符号 tinyint。数据库避免负数没有令人信服的理由,但开发人员应该依靠最小意外原则

确保 256 个值就足够了。在每天有数百万行的表中纠正错误可能会很昂贵。

于 2012-10-17T23:07:23.310 回答