I’m trying to find out if my table will get less performant if I change the primary key to BIGINT(20). At the moment, I’m using INT(7) and have about 300.000 entries already with large IDs (7 or 8 digits).
I searched a lot already but only found out that it uses more disk-space (which is obvious).
All of my IDs have 7 digits right now, but my customer wants to change to 8 digits. I won’t be able to easily change the software in the future, so I thought about using BIGINT(20) now just in case. Would it be less performant if I use BIGINT even though I don’t need to yet?
Does anyone with experience doing this have suggestions regarding speed and performance?
To answer your question: yes it’ll get less performant. Obviously, the bigger the type, the bigger the table, the slower the queries (more I/O, bigger indexes, longer access time, result less likely to fit in the various caches, and so on). So as a rule of thumb: always use the smallest type that fits you need.
That being said, performance doesn’t matter. Why? Because when you reach a point where you overflow an INT, then BIGINT is the only solution and you’ll have to live with it. Also at that point (considering you’re using an auto increment PK, you’ll be over 4 billions rows), you’ll have bigger performance issues, and the overhead of a BIGINT compared to a INT will be the least of your concerns.
So, consider the following points: