Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Как связать две таблицы в IB 6 ?

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
ramz



Зарегистрирован: 21.11.2001
Сообщения: 141

СообщениеДобавлено: Пн Апр 22 2002 16:58    Заголовок сообщения: Как связать две таблицы в IB 6 ? Ответить с цитатой

Пожалуйста, помогите разобраться...
Есть две таблицы:
table1
-name_id (smallint)
3
2
1

table2
-name_id (smallint) -name(char 25)
1 qqq
2 www
3 eee
Нужно создать из этих таблиц view:
eee
www
qqq

Как мне связать эти таблицы, чтобы я мог на формe в Buildere отображать этот View ?
Что нужно сделать с индексами (какие где подобавлять). Имеет ли смысл пользоваться IB Expert при создании этого View-ва ?
Как сделать этот view доступным в Builder ?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
swordfish



Зарегистрирован: 07.05.2002
Сообщения: 100
Откуда: Наб. Челны

СообщениеДобавлено: Вт Май 07 2002 14:08    Заголовок сообщения: Re: Как связать две таблицы в IB 6 ? Ответить с цитатой

Вопрос из области общего применения SQL.
Не могу точно сказать про IB, но по общему правилу написания SQL запросов это будет так

SELECT t1.name_id, t2.name
FROM table1 t1, table2 t2
WHERE t1.name_id=t2.name_id
ORDER BY t1.name_id

IB как уже говорил не знаю, так, что сам разберешься, создание представления что-то в этом роде:

CREATE VIEW name AS
[твое select-expression];

Если есть механизм управления синонимами.
Добавь PUBLIC синоним для твоего VIEW, если есть такой механизм в ИБ (хотя сомневаюсь).

Вопрос по индексам решаеться просто:
Если table1 - отсортированная таблица, то на нее индексы не нужны, если table2 имеет структуру примерно следующую

table2
name_id -name
1 qqq
1 www
1 eee
1 ццц
1 ууу
2 ккк
3 уке
3 ыва

То на нее индекс тоже не нужен, руководствуйся тем, что если в связанной таблице данные по столбцу надо прочитать за 40%, то индекс не нужен, если же данные не повторяющиеся или редко встречающиеся, то индекс облегчит жизнь.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
swordfish



Зарегистрирован: 07.05.2002
Сообщения: 100
Откуда: Наб. Челны

СообщениеДобавлено: Ср Май 08 2002 22:48    Заголовок сообщения: Re: Как связать две таблицы в IB 6 ? Ответить с цитатой

А обыкновенное view как ты хочешь можно сделать так:
SELECT t2.name
FROM table1 t1, table2 t2
WHERE t1.name_id=t2.name_id
ORDER BY t1.name_id

А вообще вопрос слишком простой. Учи SQL!
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...