Размер таблицы на самом деле не имеет значения, могут быть запросы, которые вы выполняете для этой таблицы.
Например, если вы выбираете пользователей на основе данных, хранящихся в таблице метаданных пользователя, этот запрос будет крайне неоптимизирован, поскольку meta_value не является индексированным полем. В этом случае вам может понадобиться добавить дополнительные индексы или рассмотреть возможность сохранения этих конкретных данных другим способом, например, с помощью пользовательской таксономии.
Вообще говоря, вещи, которые вы сохраняете как мета, никогда не должны быть предметом, который вы будете искать исключительно на основе. Это относится ко всем мета таблицам в WordPress. Meta в основном предназначен для извлечения meta_key, а не meta_value. Таксономии ограничивают возможные значения набором и упорядочивают информацию по-разному, поэтому они работают лучше, когда «значение» считается выбранным.
Обратите внимание, что выбор с помощью meta_key и meta_value, как правило, приемлем, потому что mySQL оптимизирует запрос, чтобы сначала он основывался на meta_key, уменьшая количество данных для поиска до (надеюсь) управляемого предела. Если даже это становится проблемой, вы можете «исправить» его, добавив новый индекс в мета-таблицу, указав в нем и meta_key, и meta_value, однако, поскольку meta_value - это LONGTEXT, вам нужно ограничить длину этого индекса до чего-то разумного, как 20-30 или что-то, в зависимости от ваших данных. Обратите внимание, что этот индекс может быть намного больше, чем ваши фактические данные, и значительно увеличит необходимое пространство для хранения. Тем не менее, это будет гораздо быстрее при таких типах запросов. Проконсультируйтесь с квалифицированным администратором базы данных, если это когда-либо станет реальной проблемой.
Для справки, на WordPress.org у нас зарегистрировано около 11 миллионов пользователей. Количество мета варьируется в зависимости от пользователя, с минимумом 8 строк на каждого, а может быть максимум около 250-ти. Таблица пользователей - около 2,5 ГБ, таблица пользователей - около 4 ГБ. Кажется, по большей части работает нормально, но время от времени мы находим какой-то странный запрос, который мы должны оптимизировать.