В sql_query есть второй необязательный параметр - время нахождения в кеше. Например, в коде форума обращение к таблице форумов обычно прописано так: $db->sql_query($sql, 600);
Вопрос, стоит ли использовать этот параметр при написании расширений или по умолчанию и так все запросы кешируются? Если стоит, то где предпочтительней?
Кеширование sql запросов
Правила форума
Местная Конституция | Шаблон запроса | Документация (phpBB3) | Мини [FAQ] по phpBB3.1.x/3.3.x | FAQ | Как задавать вопросы | Как устанавливать расширения
Ваш вопрос может быть удален без объяснения причин, если на него есть ответы по приведённым ссылкам (а вы рискуете получить предупреждение
).
Местная Конституция | Шаблон запроса | Документация (phpBB3) | Мини [FAQ] по phpBB3.1.x/3.3.x | FAQ | Как задавать вопросы | Как устанавливать расширения
Ваш вопрос может быть удален без объяснения причин, если на него есть ответы по приведённым ссылкам (а вы рискуете получить предупреждение

-
- phpBB Guru
- Сообщения: 16947
- Стаж: 18 лет 11 месяцев
- Откуда: Красноярск
- Благодарил (а): 549 раз
- Поблагодарили: 1699 раз
Re: Кеширование sql запросов
По умолчанию не кэшируются.
Стоит использовать только для данных, которые не требуют постоянного динамического обновления при каждой загрузке страницы.
Отправлено спустя 37 минут 33 секунды:
Для большего понимания.
Кэширование SQL запроса - это кэширование результатов SQL запроса.
То есть, например, при установке значения 600 вы в течение 10 минут будете получать для кэшированного запроса один и тот же результат, независимо от того, изменились реальные запрашиваемые значения в базе данных или нет. Результат будет загружаться не из БД, а из файла кэша.
Стоит использовать только для данных, которые не требуют постоянного динамического обновления при каждой загрузке страницы.
Отправлено спустя 37 минут 33 секунды:
Для большего понимания.
Кэширование SQL запроса - это кэширование результатов SQL запроса.
То есть, например, при установке значения 600 вы в течение 10 минут будете получать для кэшированного запроса один и тот же результат, независимо от того, изменились реальные запрашиваемые значения в базе данных или нет. Результат будет загружаться не из БД, а из файла кэша.