Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.04.08;
Скачать: [xml.tar.bz2];

Вниз

Помогите чайнику немытому связать два датасета, пожалуйста!   Найти похожие ветки 

 
ZDN   (2002-03-15 09:59) [0]

Уважаемые ГУРУ! Помогите чайнику немытому связать два датасета, пожалуйста!

Проблема такая. Есть две таблицы в БД Interbase Client и Cars.
Структура БД такая:

CREATE DATABASE "C:\database\Db.gdb" PAGE_SIZE 4096
DEFAULT CHARACTER SET WIN1251;

/* Table: CARS, Owner: SYSDBA */
CREATE TABLE CARS (IDCARS INTEGER NOT NULL,
IDCLIENT INTEGER NOT NULL,
CAR VARCHAR(20) CHARACTER SET WIN1251,
PRIMARY KEY (IDCARS));

/* Table: CLIENT, Owner: SYSDBA */
CREATE TABLE CLIENT (IDCLIENT INTEGER NOT NULL,
NAME VARCHAR(10) CHARACTER SET WIN1251,
PRIMARY KEY (IDCLIENT));

ALTER TABLE CARS ADD CONSTRAINT FK_CARS FOREIGN KEY (IDCLIENT) REFERENCES
CLIENT(IDCLIENT) ON UPDATE CASCADE ON DELETE CASCADE;

CREATE GENERATOR GEN_CLIENT_ID;
CREATE GENERATOR GEN_CARS_ID;

SET TERM ^ ;

/* Triggers only will work for SQL triggers */
CREATE TRIGGER CLIENT_BI_BI FOR CLIENT
ACTIVE BEFORE INSERT POSITION 0
AS
BEGIN
IF (NEW.IDCLIENT IS NULL) THEN
NEW.IDCLIENT = GEN_ID(GEN_CLIENT_ID,1);
END
^
CREATE TRIGGER CARS_BI_BI FOR CARS
ACTIVE BEFORE INSERT POSITION 0
AS
BEGIN
IF (NEW.IDCARS IS NULL) THEN
NEW.IDCARS = GEN_ID(GEN_CARS_ID,1);
END
^
COMMIT WORK ^
SET TERM ; ^


Создал 2 IBDataSet"а: ClientDataSet и CarsDataSet, написал для них все
запросы InsertSQL, DeleteSQL и т.п.
Включил кэширование. Для навигации по записям использую DBNavigator.
В результате все работает хорошо, но при выборе записи в главной
ClientDataSet в подчиненной
CarsDataSet не отображаются соответствующие ей записи.
Как решить эту проблему?


 
Alexandr   (2002-03-15 10:04) [1]

дык, а с чего бы они отображались?

Запросы в clientDataset и в CarsDataset приведи


 
DPetrovich   (2002-03-15 10:13) [2]

в свойстве DataSource для CarsDataSet необходимо выбрать тот DataSource который привязвн к ClientDataSet. Я так думаю.


 
Alexandr   (2002-03-15 10:16) [3]

ага, вот только запрос для CarsdataSet надо сделать соответствующим


 
data   (2002-03-15 10:23) [4]

А что, если попробовать так:
Пусть запрос QClient: select * from client. Пусть есть DataSource DSClient, которому соответствует DataSet QClient.
Запрос QCars: select * from cars where idclient=:idclient
Тогда если у запроса QCars в свойстве dataSource поставить DSClient, то при QClient.Open; QCars.Open в QCars должны отобразиться соответствующие записи.
Важно только, чтоб в QCars имя параметра соответствовало имени поля в QClient.


 
DPetrovich   (2002-03-15 11:01) [5]

to data: полностью солидарен!


 
ZDN   (2002-03-15 12:36) [6]

2 Alexandr
SelectSQL: select * from client - для ClientDataSet
InsertSQL: Insert Into client (Client) values (:Client)

SelectSQL: select * from cars - для CarsDataSet
InsertSQL: Insert Into Cars (Name) values (:Name)
При вставке в Cars /button "+" на DBNavigator/срабатывает Дельфовая процедура, в которой запрашивается уникальное значение
IDCars с сервера, а в поле IDClient пишется значение IDClient из ClientDataSet



 
Alexandr   (2002-03-15 12:48) [7]

вот и исправь SelectSQL у CarsDataSet как тебе data советует.


 
ZDN   (2002-03-15 12:53) [8]

Спасибо всем, в выходные попробую



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

Форум: "Базы";
Текущий архив: 2002.04.08;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.006 c
3-22590
onix
2002-03-18 08:36
2002.04.08
Вопрос по переносу данных с компьютера на компьютер


7-22865
MystiX
2002-01-08 12:25
2002.04.08
CD и Delphi


4-22887
Artem20000
2002-01-31 19:54
2002.04.08
Копирование файлов с помощью API


1-22654
solo
2002-03-28 11:32
2002.04.08
Вся работа стоит.


7-22857
netter
2001-12-30 10:38
2002.04.08
Удаление exe в Windows 2000





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский