Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 23.03.2011, 20:52
daraemon daraemon вне форума
Прохожий
 
Регистрация: 23.03.2011
Сообщения: 14
Репутация: 10
По умолчанию редактирование query

Доброе вам время суток, такая проблема:
Ни в какую не могу написать sql для редактирования таблицы соединенных в query.
dbgrid>>DataSource>>Query
Соединял таким способом:
Цитата:
SELECT DISTINCT glav.IDych, glav.Family, glav.Name, glav.SecName, glav.Pol, glav.DataRozh, groop.Nazvanie, gorod.Nazv, glav.Ylica, glav.Dom, glav.Kv, glav.Telefon, master.Family, glav.PocleEnd, spec.Kratkoe FROM glav, groop, gorod, master, spec
join glav on glav.IDgroop=groop.IDgroop
join glav on glav.IDgorod=gorod.IDgorod
join glav on glav.IDmaster=master.IDmaster
join glav on glav.IDspec=spec.IDspec
где то увидел что определение выбранной строки можно задать так
Цитата:
Query1.Fields[0].AsInteger;
а вот редактировать, удалить, создать, сохранить нивкакую
при том еще когда удаляешь нада удалять только из главной таблицы glav а в других оставить, но чтоб с dbgrida пропала строка
Посоветуйте, подскажите пожалуйста
Ответить с цитированием
  #2  
Старый 23.03.2011, 23:39
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,907
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Это запрос на выборку, т.е. по сути ты прочитал некий набор данных из БД. Для того чтобы изменить данные в БД следует использовать запрос на изменение. Читай на тему UPDATE.
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #3  
Старый 24.03.2011, 09:27
Black Raider Black Raider вне форума
Местный
 
Регистрация: 31.05.2010
Адрес: Москва
Сообщения: 466
Версия Delphi: 7
Репутация: 40
По умолчанию

Код:
SELECT DISTINCT glav.IDych, glav.Family, glav.Name, glav.SecName, glav.Pol, glav.DataRozh, groop.Nazvanie, gorod.Nazv, glav.Ylica, glav.Dom, glav.Kv, glav.Telefon, master.Family, glav.PocleEnd, spec.Kratkoe 
FROM glav, groop, gorod, master, spec
join glav on glav.IDgroop=groop.IDgroop
join glav on glav.IDgorod=gorod.IDgorod
join glav on glav.IDmaster=master.IDmaster
join glav on glav.IDspec=spec.IDspec 

Хмм смущает меня такой запрос вообще (*только меня интересно!?*)
Фром и джойн к одним и тем же таблицам....хммм...

а по поводу вопроса в другой квери пишите запрос вида Update [имя таблицы] SET [поле1]=[значение], [поле2]=[значение] WHERE [ключевое поле]=[значение ключ. поля]
__________________
Новый вирус - "БОМЖ"! Он просто роется в Корзине...и спит под ярлычком "Сетевое окружение"
Ответить с цитированием
  #4  
Старый 24.03.2011, 14:13
daraemon daraemon вне форума
Прохожий
 
Регистрация: 23.03.2011
Сообщения: 14
Репутация: 10
По умолчанию

Цитата:
Фром и джойн к одним и тем же таблицам....хммм...
а без джоинов будет выводить много значений на одни и те же фамилии, сделал так и все получилось как надо
проблему малость решил с помощью UpdateSQL, но не совсем,
вот например при удалении у меня строка как бы остается и не удаляется, а как перезапускаю программу так ее нет(значит удаляет, но вот почему не исчезла сразу?), можно ли как то обновить данные чтоб после удаления она всеж пропала?
DBGrid1.Refresh; невыходит
прочитал где то что с помощью update можно, дак тож не выходит, немогу понять
Ответить с цитированием
  #5  
Старый 24.03.2011, 14:21
Black Raider Black Raider вне форума
Местный
 
Регистрация: 31.05.2010
Адрес: Москва
Сообщения: 466
Версия Delphi: 7
Репутация: 40
По умолчанию

перепиши запрос :
Код:
SELECT glav.IDych, glav.Family, glav.Name, glav.SecName, glav.Pol, glav.DataRozh, groop.Nazvanie, gorod.Nazv, glav.Ylica, glav.Dom, glav.Kv, glav.Telefon, master.Family, glav.PocleEnd, spec.Kratkoe 
FROM glav
left join groop on glav.IDgroop=groop.IDgroop
left join gorod on glav.IDgorod=gorod.IDgorod
left join master on glav.IDmaster=master.IDmaster
left join spec on glav.IDspec=spec.IDspec 

DBGrid1- Это средство отображения того что в Query.
Обновляй Query т.к. после того как ты сделал Select у тебя данные кхммм... как бы хранятся в Query.
__________________
Новый вирус - "БОМЖ"! Он просто роется в Корзине...и спит под ярлычком "Сетевое окружение"
Ответить с цитированием
  #6  
Старый 24.03.2011, 15:05
daraemon daraemon вне форума
Прохожий
 
Регистрация: 23.03.2011
Сообщения: 14
Репутация: 10
По умолчанию

спасибо сейчас проверим, и еще пытаюсь добавить строку для ввода данных, использую insert правильный подход? а то я сомневаюсь потому что несколько инсертов сделать не выходит а таблиц то аж 5, не хочет показывать таблицу в dbgride если в ней хотя б одна ячейка пуста=( не знаю как быть
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра
Комбинированный вид Комбинированный вид

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 22:42.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025