Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> sarg определение, sarg 
:(
    Опции темы
марина
Дата 31.10.2007, 16:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 97
Регистрация: 2.8.2006

Репутация: нет
Всего: нет



помогите понять определение SARGABLE query:

Обязельно ли при это столбец в контсрукции where должен быть индексом?
те если я возьму и напишу такой запрос:
select * from Orders
where ShipCity = 'Barselona'
Т.о. если у меня нет индексе на ShipSity то запрос будет не sarg?

PM MAIL   Вверх
SergKO
Дата 31.10.2007, 16:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 231
Регистрация: 14.3.2005

Репутация: 3
Всего: 20



Цитата:

Способность повышения производительности запроса за счет надлежащей индексации зависит от способности оптимизатора использовать эти индексы. Условие поиска, используемое для столбца или столбцов в предложении запроса WHERE , определяет, может оптимизатор использовать индексы или нет. Разработчики должны стремиться создавать запросы, которые являются SARGable. SARG или поисковый аргумент является предложением запроса, которое оптимизатор может использовать в сочетании с индексами, созданными на таблицах поиска, чтобы выполнить фильтрацию результирующих наборов, возвращаемых запросами.

Оптимизатор запросов SQL Server имеет небольшой список условий, при которых оптимизатор не сможет использовать индексы при построении плана выполнения запроса. Следует избегать следующих ситуаций.

1. Выражения в поисковых столбцах: 
       - Математические операции, например: qty+1> 100 
        - Функции даты/времени, например: DATEPART (mm, Datecolumn) = 5 
        - Строковые функции, например: LEFT(Column,2) = 'GR' 
2. Некоторые операторы LIKE, например: LIKE '%' 
3. NOT LIKE, IS NOT NULLS, and NOT EXISTS 
4. Операции CONVERT и CAST


PM MAIL   Вверх
марина
Дата 31.10.2007, 16:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 97
Регистрация: 2.8.2006

Репутация: нет
Всего: нет



так запрос 
select * from Orders 
where ShipCity = 'Barselona'
где нет индекса  на поле ShipCity - является sarg?
(не надо цитировать определение - из него я не понимаю как ответить на такой вопрос, посто да или нет скажите плиз)

Добавлено через 2 минуты и 15 секунд
а еще если есть ссылочки на тему как NON-SARGABLE запрос  помогает распознать Execution Plan было бы здорово
PM MAIL   Вверх
SergKO
Дата 1.11.2007, 07:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 231
Регистрация: 14.3.2005

Репутация: 3
Всего: 20



Цитата(SergKO @  31.10.2007,  16:37 Найти цитируемый пост)
SARG или поисковый аргумент является предложением запроса, которое оптимизатор может использовать в сочетании с индексами, созданными на таблицах поиска, 

т.е. для того, чтобы запрос был SARGable требуется:
1. наличие индекса по полю или полям поиска;
2. Отсутствие ситуаций, которые приведены в списке, т.к. при их присутствии невозможно использовать индекс даже при его наличии.


Ссылки: поиск по SARG, и Вы получите море ссылок. Среди них будет и ссылка на статью, которую я процитировал. Я уже не помню, или на osp.ru или interface.ru.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0677 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.