0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36

Как сделать левое внешнее соединение?

03.03.2017, 15:54. Показов 2319. Ответов 33
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня есть бд на Firebird в которой хранятся две таблицы, таблица национальностей (главная) и таблица людей (дочерняя). А также программа по работе с ней, сначала выводится главная форма, а через доступ к двум справочникам. В файлах приложен документ с кодом обоих форм (а также скрины этих форм). Мне нужно сделать при помощи левого внешнего соединения так, чтобы в таблице людей вместо(!) столбца кода национальностей был столбец названия национальности, чтобы каждого человеку соответствовала своя национальность, не знаю как это соединение сделать, не выходит почему то,
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.03.2017, 15:54
Ответы с готовыми решениями:

Как сделать соединение приложений и отправлять/принимать данные в обеих направлениях?
Такая трабла не могу разгребсти как с помощью компонентов tcpclient и tcpserver в 7 версии сделать соединение приложений послать и читать...

Возможно ли сделать внешнее левое соединение таблиц с помощью оператора where?
Доброго времени суток! Возможно ли сделать внешнее левое соединение с помощью оператора where? если да, то могли бы направить меня в какую...

Использование подзапроса, левое внешнее объединение, правое внешнее объединение
Помогите составить три данных запроса

33
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
03.03.2017, 16:08
Для того чтобы ответ получить быстрее, выкладывают обычно весь проект с БД.
Описание части проекта мало что дает.
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
03.03.2017, 16:11  [ТС]
файл большой, а тут только маленький размер можно помещать
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
03.03.2017, 16:20
Об архиваторах слышали когда-нибудь (файлы rar и zip здесь принимают до 10 Мб)?
0
 Аватар для krapotkin
6851 / 4677 / 1465
Регистрация: 14.04.2014
Сообщений: 20,674
Записей в блоге: 21
03.03.2017, 16:27
кристина берет титул победителя в номинации "программирование на Делфи в Word"

весь проект состоит из нескольких пар одноименных файлов .PAS и .DFM, файла .DPR и вашей базы данных
думаю, архив с этими файлами займет меньше, чем ваша аватарка в контакте...

на самом деле, этот вопрос толком даже не относится к Делфи
вам нужно составить SQL-запрос, где будут связаны данные из таблицы людей и справочника национальностей
примерно так (все названия полей и таблиц от фонаря, ибо где взять)
SQL
1
2
3
SELECT p.first_name, p.last_name, n.nationality 
FROM persons p
LEFT JOIN nationalities n ON (n.nationality_id=p.nationality_id)
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
03.03.2017, 20:05  [ТС]
да, действительно не подумала об архиваторе, ибо не выспалась. не смешно про номинацию.

Добавлено через 1 час 40 минут
krapotkin, http://rgho.st/8Mtx6WRDW ссылка на файл. мне непонятно что значит p и n. как сделать с исходными данными
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
03.03.2017, 22:17  [ТС]
У меня есть бд на Firebird в которой хранятся две таблицы, таблица национальностей (главная) и таблица людей (дочерняя). А также программа по работе с ней, сначала выводится главная форма, а через доступ к двум справочникам. В файлах приложен архив с БД и программой. Мне нужно сделать при помощи левого внешнего соединения так, чтобы в таблице людей вместо(!) столбца кода национальностей был столбец названия национальности, чтобы каждого человеку соответствовала своя национальность, не знаю как это соединение сделать
Вложения
Тип файла: rar bd.rar (2.67 Мб, 4 просмотров)
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
03.03.2017, 22:53
Какая редиска рассказала, что нужно левое соединение?
Достаточно и обычного внутреннего:
SQL
1
2
SELECT W.*, n.nationalityname
FROM worker w JOIN nationality n ON n.nationalityid = w.nationalityid
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
03.03.2017, 22:54  [ТС]
наш преподаватель
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
03.03.2017, 22:55
Двойка этому преподавателю
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
03.03.2017, 23:29  [ТС]
он вообще сказал об этом задании только на защите курсовой, до этого молчал и ему лень было проверять говорил что все нормально у вас работает и чтобы отчет распечатывали, а во время защиты оказалось что у всей группы программы не доработаны, всех записали в должники и день сдачи перенесли, заставили в экстренном порядке переделывать а как это делать мало кто знает, сейчас попробую ваш вариант

Добавлено через 9 минут
Скандербег, вот как то так вставила, все равно ничего не поменялось

Delphi
1
2
3
4
5
6
7
8
9
10
procedure TFormMain2.FormShow(Sender: TObject);
begin
  FormFirst.DataSetWorker.SelectSQL.Clear;
   FormFirst.DataSetWorker.SelectSQL.Add
   ('SELECT W.*, n.NationalityName FROM Worker w JOIN Nationality n ON n.NationalityID = w.NationalityID');
  FormFirst.DataSetWorker.Active := True;
  FormFirst.DataSetWorker.FetchAll;
  StatusBar1.Panels[1].Text := IntToStr(FormFirst.DatasetWorker.RecordCount);
  Application.OnHint := ShowHint;
end;
Добавлено через 21 минуту
что тут можно еще исправить...
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
03.03.2017, 23:31
Цитата Сообщение от Kristina424 Посмотреть сообщение
ничего не поменялось
Ничего и не поменяется, если оставить список колонок DBGrid в том виде, в каком он был.
По крайней мере, надо бы добавить в этот список вновь созданное поле: NationalityName
Да и в компоненте DataSetWorker надо текст запроса заменить, зачем его менять в коде программы? Нелогично..
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
03.03.2017, 23:40  [ТС]
как я добавлю в таблицу поле которое вообще из другой таблицы... где его тут добавлять..
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
03.03.2017, 23:51  [ТС]
вот тут нужно вставлять запрос у компонента?
Миниатюры
Как сделать левое внешнее соединение?  
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
03.03.2017, 23:53  [ТС]
а регистр тут в запросе играет роль или нет?
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
04.03.2017, 00:03
См. картинку.
Регистр неважен.
Миниатюры
Как сделать левое внешнее соединение?  
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
04.03.2017, 00:09
Цитата Сообщение от Kristina424 Посмотреть сообщение
которое вообще из другой таблицы.
Объединение (неважно какое оно) это и есть сочетание данных из разных таблиц. Поэтому при объединении поля из другой таблицы имеют такое же право на существование, как и поля их основной таблицы.

Добавлено через 2 минуты
Цитата Сообщение от Kristina424 Посмотреть сообщение
вот тут нужно вставлять запрос у компонента?
Текст запроса вписывается в редактор свойства SelectSQL компонента DataSetWorker.
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
04.03.2017, 00:19  [ТС]
запрос я вставила, столбец добавила, новое поле появилось, но при запуске столбец названий национальности пустой
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
04.03.2017, 00:40
Не пустой.
Что не так можно понять только по вновь выложеннему проекту
Миниатюры
Как сделать левое внешнее соединение?  
0
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36
04.03.2017, 00:44  [ТС]
ну я правда не вижу где исправлять все равно выводится пустой...
Миниатюры
Как сделать левое внешнее соединение?  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.03.2017, 00:44
Помогаю со студенческими работами здесь

Левое соединение в запросах 1С.
Добрый день! Что-то никак не разберусь. Думала, что поняла, а фиг. Мне нужно запросом вытащить ВСЕХ сотрудников и если есть по ним...

Запрос: Левое соединение
Добрый день! Подскажите почему не работает левое соединение, выводит только те лицевые счета где был создан документ, а мне нужно чтобы еще...

Левое соединение двух таблиц
Форумчане, нужен совет. Как правильно сделать соединение двух таблиц. Что бы получилось так: |Контрагент|Сделка|Номенклатура| ...

Сложное левое соединение двух таблиц
Доброго времени суток форумчане! Вопрос вот в чем. Хочу в запросе выбрать таблицу1 и к ней левым соединение таблицу2. В чем сложность,...

Внутреннее и внешнее соединение
Внутреннее и внешнее соединение.Почему они так называются?


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: показать затраченные материалы за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В качестве. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru