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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Что делает оператор SELECT, в архитектуре Client-server 
:(
    Опции темы
RomanEEP
Дата 4.5.2009, 14:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 424
Регистрация: 18.5.2006
Где: Коломна

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



Что передается между клиентом и сервером и что выполняется на серваке при вызове оператора SELECT.
PM MAIL   Вверх
ZZZubec
Дата 4.5.2009, 14:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Ставишь снифер и смотриш что идет на порту 3306 (MySQL)
PM MAIL   Вверх
pompei
Дата 4.5.2009, 14:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


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

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



На серваке делаются все вычисления и сортировки, а передаётся только результат.... хотя всё зависит от драйвера.
--------------------
А всё оказывается гораздо проще: пассивные наноструктуры - активные наноструктуры - системы наносистем - молекулярные наносистемы - сингулярность! По пять лет на каждый этап.
PM MAIL   Вверх
RomanEEP
Дата 4.5.2009, 15:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 424
Регистрация: 18.5.2006
Где: Коломна

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



мне интересна сама идеалогия (я использую FirBird но думаю остальны БД работают по схожему принципу).
Мне кажется при выполнении Select, по сути передаются сам запрос к серверу и сигнал что оператор отработал к клиенту. А клиент по необходимости по команадам Next, Prev запрашивает необходимые записи из созданного набора.
Тогда, по идеи на сервере для этого создается некая таблица по которой он отправляет данные клиенту по необходимости. Я не знаю насколько это близко к реальному. Но абсолютно не ясно как работает это таблица если результат запроса содержит большое кол-во записей, сопоставимых с размерами ОП?

PM MAIL   Вверх
LSD
Дата 4.5.2009, 19:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

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



Цитата(RomanEEP @  4.5.2009,  15:41 Найти цитируемый пост)
Мне кажется при выполнении Select, по сути передаются сам запрос к серверу и сигнал что оператор отработал к клиенту. А клиент по необходимости по команадам Next, Prev запрашивает необходимые записи из созданного набора.

В принципе это зависит от реализации. Например сервер может сразу отдать первые N строк клиенту. Но вообщем и целом, это так.



Цитата(RomanEEP @  4.5.2009,  15:41 Найти цитируемый пост)
Тогда, по идеи на сервере для этого создается некая таблица по которой он отправляет данные клиенту по необходимости. Я не знаю насколько это близко к реальному. Но абсолютно не ясно как работает это таблица если результат запроса содержит большое кол-во записей, сопоставимых с размерами ОП?

Опять же зависит от реализации, но обычно сервер использует некое временное дисковое пространство для хранения курсоров.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
RomanEEP
Дата 4.5.2009, 20:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 424
Регистрация: 18.5.2006
Где: Коломна

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



Т.е. если я делаю select * from table в которой 1.000.000 записей и перекачаю с сервера только первую запись, то будет ли сервер (класса FireBird, MySQL, MSSQL, Oracle) бегать по всем строкам таблицы, что бы создать весь набор  и если нет? Могут ли быть использованы алгоритмы вроде того, что используются для поиска в Windows, т.е хранятся критерии выборки и указатель на текущую запись?
PM MAIL   Вверх
Zloxa
Дата 4.5.2009, 21:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

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



Цитата(RomanEEP @  4.5.2009,  20:33 Найти цитируемый пост)
Т.е. если я делаю select * from table в которой 1.000.000 записей и перекачаю с сервера только первую запись

За всех не могу говорить. 
Могу сказать только за оракл. 
Именно для такого запроса, оракл может выдать фетч до того как закончен скан.
Но если к запросу добавить order by по не индексированному полю, то выдать отклик до того, как закончится скан, а следом сортировка, будет невозможно.




--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
pompei
Дата 5.5.2009, 05:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


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

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



Любая "нормальная" СУБД (типа MySQL, PostgreSQL, Oracle, FireBird, ...) делает всё возможное чтобы уменьшить затраты.

Есть ещё такая фича, которая называется версионность - это когда вы делаете запрос на чтение, а БД запоминает момент времени запроса, и когда во время запроса кто-то чужой модифицирует БД, то СУБД сохраняет оригинальные значения полей (чтобы их вам дать, если надо будет) до тех пор, пока не будет до конца выполнен ваш запрос - т.е. получается, что когда вы обращаетесь к БД, для вас создаётся отдельная ваша личная неизменная версия БД на момент запроса.

Это сообщение отредактировал(а) pompei - 5.5.2009, 05:26
--------------------
А всё оказывается гораздо проще: пассивные наноструктуры - активные наноструктуры - системы наносистем - молекулярные наносистемы - сингулярность! По пять лет на каждый этап.
PM MAIL   Вверх
RomanEEP
Дата 5.5.2009, 10:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 424
Регистрация: 18.5.2006
Где: Коломна

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



Цитата(Zloxa @  4.5.2009,  21:28 Найти цитируемый пост)
Именно для такого запроса, оракл может выдать фетч до того как закончен скан.

Хорошо, а будет ли он вообще проводить скан до конца, если я не буду от него запрашивать другие записи?
Оч интересно узнать аналогичное про жарптицу!
PM MAIL   Вверх
Zloxa
Дата 5.5.2009, 11:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

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



Цитата(RomanEEP @  5.5.2009,  10:35 Найти цитируемый пост)
а будет ли он вообще проводить скан до конца, если я не буду от него запрашивать другие записи?

нет


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
nichnikov
Дата 18.5.2009, 17:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата(RomanEEP @ 4.5.2009,  13:41)
мне интересна сама идеалогия (я использую FirBird но думаю остальны БД работают по схожему принципу).
Мне кажется при выполнении Select, по сути передаются сам запрос к серверу и сигнал что оператор отработал к клиенту. А клиент по необходимости по команадам Next, Prev запрашивает необходимые записи из созданного набора.
Тогда, по идеи на сервере для этого создается некая таблица по которой он отправляет данные клиенту по необходимости. Я не знаю насколько это близко к реальному. Но абсолютно не ясно как работает это таблица если результат запроса содержит большое кол-во записей, сопоставимых с размерами ОП?

ну да,смотря какой клиент.
Если за клиента взять классы работы скриптовых языков,то реализация перехода по записям будет представлена функционалом
PM MAIL WWW ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

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

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

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

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

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


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

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

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

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

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


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

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


 




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


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

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