Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 05.02.2017
Сообщений: 36

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

03.03.2017, 15:54. Показов 2187. Ответов 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
6849 / 4676 / 1464
Регистрация: 14.04.2014
Сообщений: 20,671
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru