Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.01.16;
Скачать: CL | DM;

Вниз

TQuery & TStream   Найти похожие ветки 

 
_landy   (2002-12-19 15:37) [0]

Существует ли способ сохранить экземпляр TQuery в поток вместе со всеми полями и данными, которые вернул запрос? Вариант с отдельным сохранением данных оставлен на крайний случай.


 
Prooksius   (2002-12-19 15:40) [1]

А зачем? Опиши задачу, может, этого и не надо.


 
Serginio   (2002-12-19 15:58) [2]

Через TClientDataSet


 
_landy   (2002-12-20 10:42) [3]

Я уже думал так, но не хотелось бы привлекать для простой задачи Midas, CORBA, спец-сервер и т.д. Нужно просто передать по сети результат выполнения запроса, не более того.

Есть ли способ заставит TClientDataSet работать без Midas?


 
Prooksius   (2002-12-20 10:45) [4]


> Нужно просто передать по сети результат выполнения запроса

Странно, а может просто послать запрос к базе с той машины, куда ты хочешь передать этот результат? Ведь так легче.


 
_landy   (2002-12-20 12:18) [5]

Так легче, но так делать нельзя по условиям задачи. Необходимо трехзвенное приложение для работы на тонком канале, где нет возможности поднять BDE или ODBC. Да и передача идет только в одну сторону, update делать тоже не надо, только select.


 
Reindeer Moss Eater   (2002-12-20 12:21) [6]

TStream + TWriter + соглашение о заголовке пакета между "серединой" и "клиентом"


 
_landy   (2002-12-20 12:54) [7]

Именно с этого я и начинал. Создавал поток и вызывал WriteComponent (Query). Насколько написано в доке, экземпляр TWriter создается автоматически. Проблема в том, что данные (результат выполнения запроса) таким образом не сохраняются, сохраняются только properties объекта.


 
Reindeer Moss Eater   (2002-12-20 13:01) [8]

Ну так все правильно.
На клиенте тебе нужна копия экземпляра TQuery или сами данные?
Думаю что данные.
Для этого в поток нужно писать данные, а не компонент.


 
_landy   (2002-12-20 14:33) [9]

Это все да, просто предполагалось мне, что есть решение по передаче всего объекта целиком, вместе с данными. Чтоб на другой стороне опять все в экземпляр TQuery не заталкивать, дабы прозрачность этого процесса организовать. Но, если нет, так и буду делать.


 
Sergey Masloff   (2002-12-22 22:06) [10]

_landy (20.12.02 10:42)
>Я уже думал так, но не хотелось бы привлекать для простой >задачи Midas, CORBA, спец-сервер и т.д. Нужно просто передать >по сети результат выполнения запроса, не более того.

>Есть ли способ заставит TClientDataSet работать без Midas?

Если у тебя УЖЕ есть приложение на сервере из которого ты хочешь передать TQuery клиенту какие у тебя основания не хотеть использовать МИДАС с его стандартными опробованными средствами и городить свой огород? TClientDataSet без мидас работать может конечно. Пиши сервер, клиент посылает ему текст запроса (через, допустим, сокетконнекшн) сервер загружает SQL в TQuery.SQL, открывает запрос, фетчит все записи, потом берешь собираешь все данные, например, в XML, этот XML компрессуешь, передаешь клиенту, он парсит XML, вытаскивает данные о полях, создаешь динамически поля для TClientDataSet, потом их программно заполняешь. Потом можешь наслаждаться ;-))




Страницы: 1 вся ветка

Текущий архив: 2003.01.16;
Скачать: CL | DM;

Наверх




Память: 0.46 MB
Время: 0.009 c
1-48992
ShelbiX
2003-01-06 23:41
2003.01.16
Фокус


1-49058
bvn123
2003-01-04 12:15
2003.01.16
Как получить полное имя файла запущенного приложения в нем самом


1-49062
stainer
2003-01-08 11:27
2003.01.16
в виндах есть задержка на отображение меню (по умолчанию по моему


3-48911
Calm
2002-12-19 14:06
2003.01.16
В чем отличие dialect1 от dialect3?


3-48941
Iren
2002-12-23 06:40
2003.01.16
ADO





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский