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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Можно коротко объяснить зачем нужны представления? 
:(
    Опции темы
phpmas
Дата 26.6.2011, 10:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Можно коротко объяснить зачем нужны представления?
PM MAIL   Вверх
Zloxa
Дата 26.6.2011, 10:54 (ссылка) |    (голосов:3) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(phpmas @  26.6.2011,  10:48 Найти цитируемый пост)
коротко 

Цитата(phpmas @  26.6.2011,  10:48 Найти цитируемый пост)
зачем нужны представления? 

они предоставляют возможность абстрагировать клиентское приложение от физического представления данных.



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


Творец
****


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

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



Можно сделать очень сложный запрос, а на клиенте выполнить просто select .... from <представление>.
Клиент может всё время выполнять select .... from <представление> и даже не зная о том, что на сервер условия запроса могут меняться.

Допустим есть таблица с именем Table1 и представление с точно таким же именем. Если выполнить select .... from Table1, то запрос обратиться НЕ к таблице, а к представлению.

Добавлено через 4 минуты и 4 секунды
Представление, это как бы поименованный запрос.
PM MAIL   Вверх
Akina
Дата 28.6.2011, 12:24 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


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

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



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


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
Frees
Дата 28.6.2011, 19:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


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

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



Цитата(Akina @  28.6.2011,  15:24 Найти цитируемый пост)
Если всё завязано непосредственно на таблицы, то изменение структуры ведёт к переписыванию всех запросов, задеваемых изменением. Пример - содержимое некоего поля вынесено в таблицу-справочник, и вместо текстового поля у нас теперь ссылка на эту таблицу... и во все запросы приходится добавлять эту таблицу с соотв. джойном, вносить соотв. правки... застрелиться.

это ты описываешь идеальный вариант,  на практике ни разу не было таких изменений что бы не пришлось править view.
это я к тому что надо долго думать перед тем как  определить view.




--------------------
Кольцов Виктор Владимирович
PM MAIL ICQ   Вверх
Zloxa
Дата 28.6.2011, 21:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(Frees @  28.6.2011,  19:06 Найти цитируемый пост)
 на практике ни разу

Даже когда исправить надо лишь план запроса? smile 

На моей практике... 

Внешние системы и репортеры, в абсолютном своем большинстве смотрят в базу исключительно через интерфейсные вьюхи. Для разраба преимущества такого подхода еще и в том, что в случае уточнения схемы данных поврежденные объекты становятся известны сразу, а не в процессе исполнения.

Клиентские же приложения, не всякий раз смотрят во вьюхи, но как правило. Особенно в случаях, когда модификация таблы влечет за собой сколь нибудь сложные и обильные пересчеты. Приходится ее выполнять средствами instead of триггеров,  как минимум для того, чтобы управлять порядоком захвата блокировок и избегать дедлоков. /* Впрочем, это еще и средство обхода специфичного для оракла ограничения на чтение мутирующих источников данных */




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


Советчик
****


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

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



Цитата(Frees @  28.6.2011,  20:06 Найти цитируемый пост)
на практике ни разу не было таких изменений что бы не пришлось править view.

А я для кого пишу, что
Цитата(Akina @  28.6.2011,  13:24 Найти цитируемый пост)
после изменения структуры откорректировать текст запроса представления 

?


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
Zloxa
Дата 29.6.2011, 08:44 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Akina, я полагаю Frees имел в виду что в подавляющем большинстве случаев, при уточнении схемы данных приходится менять и структуру вьюхи - набор возвращаемых ею полей. И это, в свою очередь, влечет за собой перекомпиляцию приложения.

Это сообщение отредактировал(а) Zloxa - 29.6.2011, 08:45


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


Советчик
****


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

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



Цитата(Zloxa @  29.6.2011,  09:44 Найти цитируемый пост)
при уточнении схемы данных приходится менять и структуру вьюхи 

Гм... вот это как раз странно. И в этом случае как раз от наличия вьюхи нет никакого профиту.
Но такое возможно лишь, если появляется новая сущность или новый атрибут сущности, вроде - а это уже далеко не изменения в способе хранения данных (приведение структуры из дебильного вида к каноническому не рассматриваем).


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
Zloxa
Дата 29.6.2011, 12:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(Akina @  29.6.2011,  11:49 Найти цитируемый пост)
Но такое возможно лишь, если появляется новая сущность или новый атрибут сущности,

Ну да.. и именно такого рода уточнения схемы превалируют на практике ))) И именно по этой причине может показаться что выставлять оголтело вьюхи клиентам не имеет особого смысла. Казалось бы, если потребуется радикальным образом поменять структуру хранения, ничего не мешает сделать alter table rename, create veiw as select * from ..... Однако, из той же практики, средства доступа, бывает, несколько по разному рабтают с вьюхами и таблами. И когда мы таблу подменяем вьюхой, приложение перестает работать. Потому я, лично, предпочитаю сразу выставить гуйпрогеру вьюхи, чтобы не ограничиать себя в дальнейшем и, если чо, не идти к нему с поклоном, "мол прости засрантса, не подумал сразу, ты уж перепши там, чтоб обратно все заработало"


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


Эксперт
****


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

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



Цитата(Zloxa @  29.6.2011,  11:44 Найти цитируемый пост)
Akina, я полагаю Frees имел в виду что в подавляющем большинстве случаев, при уточнении схемы данных приходится менять и структуру вьюхи - набор возвращаемых ею полей. И это, в свою очередь, влечет за собой перекомпиляцию приложения.


Именно это я и хотел сказать.


Цитата(Zloxa @  29.6.2011,  00:37 Найти цитируемый пост)
Даже когда исправить надо лишь план запроса?

а разве план запроса из view не зависит от того как запрашиваешь? например дописал условие к селекту из view план поменяется.. или я неправ?


--------------------
Кольцов Виктор Владимирович
PM MAIL ICQ   Вверх
Zloxa
Дата 29.6.2011, 13:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



[чушь. не правильно понял вопрос]

Добавлено через 6 минут и 9 секунд
Цитата(Frees @  29.6.2011,  12:53 Найти цитируемый пост)
 или я неправ? 

Ты прав. Но на план модифицированного запроса тоже можно влиять изменяя текст вьюхи. Хинты, альтерварианты и пр...

Это сообщение отредактировал(а) Zloxa - 29.6.2011, 13:06


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

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

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

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

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

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


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

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

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

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

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


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

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


 




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


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

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