Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
10 / 10 / 3
Регистрация: 19.03.2010
Сообщений: 679
Записей в блоге: 2
1

Метод обновления данных в ADO

18.01.2012, 10:32. Показов 2692. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть такой метод у компонент Query или StoreProc, чтобы он обновлял данные которые уже в них хранятся? Т.е чтобы не надо было каждый раз делать им Active = false, Active = true
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
18.01.2012, 10:32
Ответы с готовыми решениями:

Не удается найти строку для обновления ADO
доброго времени суток. есть база на mysql. есть проблема при изменении у записи значения 1...

Базы данных ADO
Все привет! у меня возникла такая проблема.. я работаю с компонентами страницы палитры компонентов...

Типы данных ADO
Есть таблица с полями id, detail, mark, count, cost обозначающие уникальный номер, деталь, марку...

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

5
512 / 298 / 37
Регистрация: 22.06.2011
Сообщений: 929
18.01.2012, 10:49 2
"
Метод Refresh() используется не у всех наследников TDataSet. Например, его вызов
не имеет смысла для компонентов-запросов TQuery и TStoredProc, т. к. эти эле-
менты управления по определению не работают с «живыми» данными. А для обнов-
ления устаревших результатов достаточно отправить запрос повторно, вызвав
последовательно методы Close() и Open().
"
0
10 / 10 / 3
Регистрация: 19.03.2010
Сообщений: 679
Записей в блоге: 2
18.01.2012, 12:06  [ТС] 3
для компонентов-запросов TQuery и TStoredProc чтобы обновить данные только методы Close() и Open() использоать? и все?!
0
1496 / 1238 / 244
Регистрация: 04.04.2011
Сообщений: 4,362
18.01.2012, 13:18 4
Во-первых, в ADO указанные компоненты являются клонами, причем не самыми удачными, от TADODataSet и их использование нежелательно, мягко говоря.

Во-вторых, для получения результатов выборки на клиенте предназначен TADODataSet.
У него, как впрочем и у всех наследников TCustomADODataSet есть метод ReQuery, который при клиентском курсоре практически аналогичен переоткрытию НД (повторное выполнение запроса из св-ва CommandText). Для серверного курсора есть особенности - о них можно узнать подробно из справки Делфи ADO.

В-третьих, если Вы намекаете об отсутствии автообновления (по образу BDE+парадокс), то да, в ADO не предусмотрен такой механизм. Однако в АДО оставлен "лючок" для того, чтобы в случае если DAC + провайдер + скл-сервер поддерживают событийную модель изменений в БД, можно было реализовать это самой автообновление. Вопрос в том, а нужно ли оно по жизни ? Как показывает практика, автооповещение клиента сервером и соотвтетственно автобновление ТОЛЬКО ИЗМЕНИВШИХСЯ ОТОБРАЖАЕМЫХ В ТЕКУЩИЙ МОМЕНТ записей самим клиентом действительно необходимо лишь в очень небольших предметных областях (мониторинг например). Однако данная проблема является одной из самых частых на форумах программистов и дискуссии протекают как правило в русле холиваров
По моему глубокому убеждению среди сторонников "автообновления" большинство - неопытные или не слишком умелые проектировщики баз данных (известно, что далеко не всегда хороших программист = хороший "базовик" и наоборот) и проблема возникает не из-за "глюкавости" АДО, а из-за плохо продуманной модели интерфейса (как очень частый пример - "складские" программы, в которых документы на перемещение: накладные, акты списания, счета-фактуры и т.д. отсутствуют как самостоятельные объекты БД и программа оперирует "товаром вообще".)
0
10 / 10 / 3
Регистрация: 19.03.2010
Сообщений: 679
Записей в блоге: 2
18.01.2012, 13:21  [ТС] 5
Вот как я вижу картину: делаю запрос в АДО процедуре, она получает набора данных в ДатаСет, и держит их там, потом я например хочу получить из того же набора данных определенную часть по фильту, для этого надо опять тянуть весь запрос из скл так? другого пути нет?
0
1496 / 1238 / 244
Регистрация: 04.04.2011
Сообщений: 4,362
18.01.2012, 14:04 6
Существует два способа обработки данных (фильтрация/отбор, сортировка, поиск) - на стороне сервера и на стороне клиента.
На стороне сервера обработка осуществляется запросами, т.е. для сортировки например надо переделать запрос соответствующим способом (order by) и "попросить" сервер выполнить его, фактически перечитав те же данные., но с учетом подтвержденных на момент старта выборки изменений, сделанных другими пользователями (транзакциями). Другими словами, перезапуская запрос, клиент автоматически и "освежает" (актуализирует) информацию сервера.

На стороне клиента все операции с данными выполняются в локальном адресном пространстве без учета изменений, внесенных в БД на сервере . Т.е. если Вы просто пересортируете НД (TCustomADODataSet.Sort), то записи просто перестроятся, но не изменятся (актуализируются). Для того, чтобы актуализировать НД нато перечитать его с сервера либо полностью (В ADO Reopen, Close/Open) либо частично ("тонкая" работа с ADO или "заточенный" под сервер DAC при условии что он (сервер) такое позволяет)

Добавлено через 4 минуты
В ADO выбор технологии между клиентом и сервером реализуется через св-ва TADOConnection
У каждой есть свои плюсы и минусы, поэтому окончательный выбор зависит от предметной бласти, технологии обработки данных и требованию к пользовательскому интерфейсу.
0
18.01.2012, 14:04
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.01.2012, 14:04
Помогаю со студенческими работами здесь

Фильтрация данных ADO
Здравствуйте форумчане. Возникла проблема при фильтрации данных. Когда Поле эдита пустое, вылетает...

База данных ADO
Всем привет. В общем дело такое, я через ADO загружаю *dbf таблицу в ДЕЛФИ. И я эту таблицу с...

Treeview, из базы данных ADO!
3-ий день голову ломаю не могу сообразить, дело в том что необходимо что бы дерево создавалось из...

Добавление данных ADO access
Можете посмотреть в чем проблема при нажатии на кнопку добавление. Я там заполняю 2...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru