INT, по умолчанию SIGNED; диапазон от -2 млрд до +2 млрд. Он занимает 4 байта. Но AUTO_INCREMENTs никогда не будут отрицательными, поэтому INT UNSIGNED будет лучше - от 0 до + 4 миллиардов (и еще 4 байта).
4 миллиарда - это более половины населения мира. Если вы приближаетесь к этому числу «любит», кто-то обманывает, и вы должны подключить это отверстие.
Ditto for post_id. И user_id. (Ой, я опережаю себя.)
пользователь VARCHAR (40) CHARACTER SET latin1 - Если вы надеетесь получить даже отдаленно близкое к 4 миллиардам, вам нужно позволить китайцам, тайцам, корейцам и т. Д. , in. Используйте utf8mb4.
Нужны ли вам пользователи для регистрации? (В противном случае, как вы можете помешать кому-либо «набивать урну для голосования»?) У вас есть другая таблица под названием Users
? И у него есть AUTO_INCREMENT? И этот id является 4-байтным INT UNSIGNED? Итак, не используйте здесь полное имя; используйте этот идентификатор. Меньше -> больше cacheable -> меньше ввода-вывода -> быстрее.
PARTITION? Нет. Не используйте PARTITIONING, не понимая, что мало он может сделать и сколько он не может сделать. Он не обеспечивает скорость; конечно нет для этого использование случай.
ДВИГАТЕЛЬ = MyISAM. У вас когда-либо была сбой питания на сервере с таблицей MyISAM на миллиард строк? Когда сервер выполняет резервное копирование, он начинает жаловаться на поврежденную таблицу. Вы проводите несколько часов, выясняя, что это значит. Затем вы запустите REPAIR TABLE. Через несколько часов заканчивается. Между тем система недоступна. Используйте ENGINE = InnoDB.
Что заставляет вас думать, что у вас есть проблема с тем, как это происходит? –
@HoboSapiens спасибо за ваш ответ! да, проблема в том, что эта таблица станет больше, мой вопрос в том, поддержит ли она миллионы, миллиарды? он не станет медленным? int (11) или bigint? могу ли я разбить его быстрее? или, я не знаю, как я мог бы улучшить эту таблицу, чтобы быть быстрее, когда она получает несколько просмотров в секунду ... хорошо ли это? –