Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.58/12: Рейтинг темы: голосов - 12, средняя оценка - 4.58
0 / 0 / 1
Регистрация: 26.04.2011
Сообщений: 17
1

Опять про связь таблиц

31.05.2011, 16:31. Показов 2215. Ответов 26
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Как бы покороче. Есть две таблицы
1. Sector(Name, Code) сектор
2. Line(Name, Code, Sector) линия

Вторая таблица связана с первой ключем(Sector+Code)

На форме Edit1, DBLookupComboBox1, CxGrid1, Button1

Значения DBLookupComboBox1 равны Sector(Name)

В поле Edit1 вводим название линии в DBLookupComboBox1 выбираем сектор и при нажатии
Button1 в CxGrid1(Name, Sector) тоесть в таблицу Line должна попасть информация о новой линии которая соответствует даному сектору.

C++
1
2
3
4
5
6
7
8
9
10
ADOQuery1->Close();
ADOQuery1->SQL->Clear();
 
ADOQuery1->SQL->Add( "INSERT INTO Line (Name,Sector) VALUES('"+ Edit1->Text + "','"+ DBLookupComboBox1->Text +"')" );
 
ADOQuery1->ExecSQL();
DataSource1->DataSet->Close(); 
ADOTable1->TableDirect=true;
DataSource1->DataSet->Open();
Edit1->Clear();
в третей строке проблема не могу разобраться. Помогите. Заранее спасибо!
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
31.05.2011, 16:31
Ответы с готовыми решениями:

Связь нескольких таблиц
Всем привет! Подскажите как лучше реализовать следующую задумку. Есть база с несколькими...

Связь таблиц через ADOQuery
Ребята помогите связать таблице через ADOQuery через ключевой столбец в С++ Builder! Я хочу...

Связь двух таблиц с помощью query
Доброй ночи, необходимо сделать так что бы в dbgrid2 отображались данные на основании dbgrid1. ...

Опять про COM порт
Здравствуйте. Наверняка данный вопрос уже неоднократно появлялся, но т.к. я к сожалению не...

26
0 / 0 / 1
Регистрация: 26.04.2011
Сообщений: 17
02.06.2011, 15:24  [ТС] 21
Author24 — интернет-сервис помощи студентам
C++
1
2
3
4
5
6
7
8
9
10
11
ADOQuery1->Close();
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add( "INSERT INTO Line (Name,Sector) VALUES('"+ Edit1->Text + "','"+ ADOTable2->FieldByName("Code")->AsString +"')" );
ADOQuery1->SQL->Add( "SELECT Line.Name, Sector.Name *FROM Line, Sector")
ADOQuery1->ExecSQL();
 
 
DataSource1->DataSet->Close();
ADOTable1->TableDirect=true;
DataSource1->DataSet->Open();
Edit1->Clear();
та же ошибка
cxGrid1 привязан к DataSource1
DataSet в DataSource1 подключен ADOQuery1
0
1496 / 1238 / 244
Регистрация: 04.04.2011
Сообщений: 4,362
02.06.2011, 15:56 22
Вот объясните зачем Вы раз от разу лепите звезду после списка полей и без пробела перед "from", в каком SQL-стандарте такая конструкция позволяется ?
И второе - Вы таки хотите декартово получить или просто забыли про "where", устанавливающую связующее две таблицы условие выборки ?
0
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
02.06.2011, 16:05 23
Цитата Сообщение от MsGuns Посмотреть сообщение
Вот объясните зачем Вы раз от разу лепите звезду после списка полей и без пробела перед "from", в каком SQL-стандарте такая конструкция позволяется ?
Лепит он потому что я ему об этом написал по ошибке. Так что прошу прощения
0
0 / 0 / 1
Регистрация: 26.04.2011
Сообщений: 17
02.06.2011, 16:24  [ТС] 24
Хорошо переписал так
C++
1
ADOQuery1->SQL->Add( "SELECT Name FROM Line WHERE Code >0 UNION SELECT Name FROM Sector WHERE Code>0") ;
все равно ничего говорит что поле Sector(Name) носит не тот формат int
0
1496 / 1238 / 244
Регистрация: 04.04.2011
Сообщений: 4,362
02.06.2011, 17:10 25
"Все равно", говорите ?
А запрос изменили при этом кардинально.

Вам нужно не объединять результаты запросов (для чего служит кляуза UNION), а задать связующее две таблицы условие. Вам надо элементарно азы SQL.

Лучше всего отлаживать запросы не в си, а напрямую, например в самом акцесе, а уже готовый, протестированный запрос переность в TADOQuery или куда там еще.

Добавлено через 55 секунд
Дайте сюда структуры обеих таблиц и задачу ЧТО ВЫ ХОТИТЕ ВЫБРАТЬ ?
0
0 / 0 / 1
Регистрация: 26.04.2011
Сообщений: 17
03.06.2011, 10:32  [ТС] 26
структура таблиц в шапке темы. там вроде ясно изложил хочу выбрать два поля
1 из Line(Name)
2 из Sector(Name)

Добавлено через 20 минут
чтоб не путаться переименовал Sector(Name) в Sector(NameSector). напрямую в редакторе скриптов на менеджере такой скрипт работает
SELECT Name,NameSector FROM Line, Sector.
но ничего данные так и не отбирает.

Добавлено через 16 часов 47 минут
Извиняюсь разобрался данные отбирает нашел ошибку . просто DataSourse использовал одновременно два скрипта SQL

Добавлено через 10 минут
гы поспешил радоваться выдает результат каждую линию по всех секторах видимо нужно дописать WHERE
0
1496 / 1238 / 244
Регистрация: 04.04.2011
Сообщений: 4,362
03.06.2011, 12:42 27
Я Вам про декартово говорил еще в [22] (почти сутки назад). Если не знаете что такое "декартово", это Вас не извиняет - гугл на то.
Про звездочку тоже базар шел сутками.
Так и не ясно, выкинули Вы Union или нет.
Если Вы так "внимательно" будете читать что Вам пишут, то к Страшному суду может быть и отладитесь.

В общем я удаляюсь, удачи Вам и счастья в личной жизни.
0
03.06.2011, 12:42
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.06.2011, 12:42
Помогаю со студенческими работами здесь

Query связь 2-х таблиц
Уважаемые программисты помогите пожалуйста разобраться!!!. имеются 2-е таблицы Tab1 (Imya, Fam,...

Вопрос про связь двух таблиц
День добрый! Как правильно определить связь между таблицами "Сотрудники" и "Организации"? В...

Vopros дурацки :) про связь таблиц
итак, дело касаемо расчета себестоимости. есть рег накопления "себестоимость" остатки+ обороты....

Вопрос про обратную связь, и про схемотехнику полумоста
Добрый день) Я сейчас делаю схему от уважаемого rost c форума http://www.psb-kots.ru/forum/ , и...


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

Или воспользуйтесь поиском по форуму:
27
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru