Отправляет email-рассылки с помощью сервиса Sendsay

RFpro.ru: СУБД и Delphi/Lazarus

  Все выпуски  

RusFAQ.ru: СУБД и Delphi


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Шичко Игорь
Статус: Студент
Рейтинг: 265
∙ повысить рейтинг >>
Виктор Пырлик
Статус: Профессионал
Рейтинг: 60
∙ повысить рейтинг >>
Командин Константин Евгениевич
Статус: 5-й класс
Рейтинг: 41
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / СУБД и Delphi

Выпуск № 513
от 12.11.2008, 03:05

Администратор:Gh0stik
В рассылке:Подписчиков: 252, Экспертов: 24
В номере:Вопросов: 1, Ответов: 1

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 149734: Здравствуйте ув. эксперты! Подскажите в чем различие между TDataSet и TQuery. Я понимаю что TQuery это класс-потомок TDataSet'a. Но в чем разница в применение и когда лучше применять тот или иной компонент! Спасибо!...


Вопрос № 149.734
Здравствуйте ув. эксперты!
Подскажите в чем различие между TDataSet и TQuery. Я понимаю что TQuery это класс-потомок TDataSet'a. Но в чем разница в применение и когда лучше применять тот или иной компонент!
Спасибо!
Отправлен: 07.11.2008, 02:46
Вопрос задал: Малых Константин (статус: Посетитель)
Всего ответов: 1
Мини-форум вопроса >>> (сообщений: 0)

Отвечает: sir Henry
Здравствуйте, Малых Константин!
© Цитата:
Я понимаю что TQuery это класс-потомок TDataSet'a.

Различие как раз в этом.
Для чего нужны классы-предки? Они предоставляют некий базовый функционал, который присутствует у всех классов-потомков без исключения.
А для чего нужны классы-потомки? В подавляющем большинстве случаев нам нужен не класс-универсал, который может всё и поэтому монстрообразен, а некий компактный класс с некими необходимыми и специфическими свойствами. Например класс-потомок TQuery вводит такое специфическое свойство - SQL. В этом свойстве содержится текст запроса к базе данных. Далее, по логике, есть свойство отпра влять запрос к базе данных (Open и ExecSQL, в зависимости от вида запроса) и только после этого вступает в игру базовое свойство, которое досталось в наследство от TDataSet, т.е. возможность хранить у себя данные, полученые после выполнения запроса.
Когда их лучше применять.
TQuery, уже исходя из названия, лучше применять для получения данных из БД, причём не всех подряд, а по заданному условию. В результате Вы получите готовые к употреблению данные не нуждающиеся в дополнительной обработке. А вот другой потомок TDataSet'а - TTable, нам такой возможности уже не даёт и поэтому в нём приходится прикладывать какие-то дополнительные, иногда нетривиальные, усилия для того, чтобы полученными данными можно было любоваться.
TDataSet лучше всего применять для построения нового класса, который требует присутствия у себя набора данных. Например, на основе TDataSet построен класс TDbf, который работает исключительно с таблицами формата DBF. В TDataSet присутствуют все необ ходимые базовые свойства - открыть, закрыть источник данных, поиск в наборе данных, добавление, удаление и т.п., но нет привязки к конкретному источнику данных - к FireBird' у например или к Paradox'у, привязку уже выполняет программист в классе-потомке.
Ответ отправил: sir Henry (статус: Академик)
Россия, Красноярск
----
Ответ отправлен: 07.11.2008, 07:09

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 234637 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

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


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2008, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.11 от 9.11.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное