gpt4 book ai didi

sql - 我应该使用整数主 ID 吗?

转载 作者:搜寻专家 更新时间:2023-10-30 19:55:46 24 4
gpt4 key购买 nike

例如,我总是为用户表生成一个自增字段,但我还在他们的用户名上指定了一个 UNIQUE 索引。在某些情况下,我首先需要获取给定用户名的 userId,然后执行所需的查询,或者在所需的查询中使用 JOIN。这是访问数据库或 JOIN 与 varchar 索引的 2 次访问。

我应该使用整数主 ID 吗?

小型 VARCHAR 索引相比,INT 是否具有真正的性能优势?

最佳答案

代理主键有几个优点,包括:

当你在另一个表中有一个外键时,如果它是一个整数,它只占用几个字节的额外空间并且可以快速连接。如果您使用用户名作为主键,它将必须存储在两个表中 - 占用更多空间,并且在您需要加入时需要更长的时间进行比较。

如果用户希望更改他们的用户名,如果您将其用作主键,则会遇到大问题。虽然可以更新主键,但这样做是非常不明智的,并且可能会导致各种问题,因为该键可能已被发送到各种其他系统、用于链接、保存在备份、日志中已存档等。您无法轻松更新所有这些地方。

关于sql - 我应该使用整数主 ID 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2660124/

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