- Поисковые системы
- Практика оптимизации
- Трафик для сайтов
- Монетизация сайтов
- Сайтостроение
- Социальный Маркетинг
- Общение профессионалов
- Биржа и продажа
- Финансовые объявления
- Работа на постоянной основе
- Сайты - покупка, продажа
- Соцсети: страницы, группы, приложения
- Сайты без доменов
- Трафик, тизерная и баннерная реклама
- Продажа, оценка, регистрация доменов
- Ссылки - обмен, покупка, продажа
- Программы и скрипты
- Размещение статей
- Инфопродукты
- Прочие цифровые товары
- Работа и услуги для вебмастера
- Оптимизация, продвижение и аудит
- Ведение рекламных кампаний
- Услуги в области SMM
- Программирование
- Администрирование серверов и сайтов
- Прокси, ВПН, анонимайзеры, IP
- Платное обучение, вебинары
- Регистрация в каталогах
- Копирайтинг, переводы
- Дизайн
- Usability: консультации и аудит
- Изготовление сайтов
- Наполнение сайтов
- Прочие услуги
- Не про работу
Авторизуйтесь или зарегистрируйтесь, чтобы оставить комментарий
Координаты вида 37.457627 (6 знаков после запятой) в данный момент хранятся в таблице в поле varchar(32).
Можно ли безболезненно перевести это поле в другой тип чтобы запросы типа SELECT отрабатывали быстрее?
например:
AS category_title, t4.geo_lat, t4.geo_long, CONCAT_WS('-', t1.id, t1.alias)
AS item_alias, CONCAT_WS('-', t2.id, t2.alias)
....блаблабла.....
WHERE (t4.geo_long BETWEEN 37.539317933619 AND 37.559317933619) AND (t4.geo_lat BETWEEN 55.540176183019 AND 55.560176183019)
LIMIT 300
Пока изучаю вопрос по возможности сменить поле и не трогать запросы.
к числу приведите и будет быстрее
Можно перевести в float по шаблону с количеством знаков после точки.
Но тут могут быть накладки с разделителем чисел. Надо отслеживать это.
к числу приведите и будет быстрее
Можно подробнее - что сделать то надо? (я не кодер, попроще если можно)
Decimal и 5 знаков после запятой по идее хватает. По крайней мере скармливая гуглу координаты с 5 знаками и с 10 - разницы в позиции точки не увидел.
Сменил типа поля на Decimal (8,6)
врая запрос при varchar - 0.1162 сек
при Decimal - 0,06
Спасибо!
при Decimal - 0,06
ИМХО результат в области погрешности :)
decimal, например
опоздал :)