|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
|||
|
|||
редактирование query
Доброе вам время суток, такая проблема:
Ни в какую не могу написать sql для редактирования таблицы соединенных в query. dbgrid>>DataSource>>Query Соединял таким способом: Цитата:
Цитата:
при том еще когда удаляешь нада удалять только из главной таблицы glav а в других оставить, но чтоб с dbgrida пропала строка Посоветуйте, подскажите пожалуйста |
#2
|
||||
|
||||
Это запрос на выборку, т.е. по сути ты прочитал некий набор данных из БД. Для того чтобы изменить данные в БД следует использовать запрос на изменение. Читай на тему UPDATE.
Некоторые программисты настолько ленивы, что сразу пишут рабочий код. Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты. |
#3
|
|||
|
|||
Код:
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
|
|||
|
|||
Цитата:
проблему малость решил с помощью UpdateSQL, но не совсем, вот например при удалении у меня строка как бы остается и не удаляется, а как перезапускаю программу так ее нет(значит удаляет, но вот почему не исчезла сразу?), можно ли как то обновить данные чтоб после удаления она всеж пропала? DBGrid1.Refresh; невыходит прочитал где то что с помощью update можно, дак тож не выходит, немогу понять |
#5
|
|||
|
|||
перепиши запрос :
Код:
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
|
|||
|
|||
спасибо сейчас проверим, и еще пытаюсь добавить строку для ввода данных, использую insert правильный подход? а то я сомневаюсь потому что несколько инсертов сделать не выходит а таблиц то аж 5, не хочет показывать таблицу в dbgride если в ней хотя б одна ячейка пуста=( не знаю как быть
|
#7
|
|||
|
|||
Цитата:
|
#8
|
|||
|
|||
теперь бы с добавлением строки разобраться=(
Цитата:
|
#9
|
|||
|
|||
Подход правильный. Почему ж несколько инсертов не выходит?
а вот не показывает он не таблицу а запись в которой хотя б одно поле пустое после выполнения вашего запроса. В случае если подставите мой запрос по он покажет все записи из таблицы glav и дополнит их данными из доп. таблиц. Новый вирус - "БОМЖ"! Он просто роется в Корзине...и спит под ярлычком "Сетевое окружение" |
#10
|
|||
|
|||
ну я попробывал вот так вот поиздеваться и ничего не вышло=( SQL не знаю вообще, 2ой день с учебником парюсь.. не судите строго
Цитата:
|
#11
|
|||
|
|||
Код:
Query2.Close; Query2.SQL.Clear; Query2.SQL.Add('insert into glav '); Query2.SQL.Add('(Name, Family, SecName, DataRozh, Pol, Ylica, Dom, Kv, Telefon, PocleEnd, IDych) '); Query2.SQL.Add('values (:Name, :Family, :SecName, :DataRozh, :Pol, :Ylica, :Dom, :Kv, :Telefon, :PocleEnd)'); Query2.parametrs.parambyname('Name').value:='Name'; и т.д. Query2.execSql; Код:
Query2.Close; Query2.SQL.Clear; Query2.SQL.Add('insert into master (Family) '); Query2.SQL.Add('values(:Family)'); Query2.parametrs.parambyname('Family').value:='Family'; Query2.execSql; Новый вирус - "БОМЖ"! Он просто роется в Корзине...и спит под ярлычком "Сетевое окружение" |
#12
|
|||
|
|||
ооо спасибо огромное, а под query1 если сделать, ничего плачевного не будет?
а даже если под query2 то соединять прийдется? |
#13
|
|||
|
|||
Не будет, разве что в гриде у вас не будет отображаться
вообще для Select и Update,Insert,Delete лучше использовать разные квери. Объединять все равно надо если вы хотите получить нужные вам данные. Новый вирус - "БОМЖ"! Он просто роется в Корзине...и спит под ярлычком "Сетевое окружение" |
#14
|
|||
|
|||
а неподскажете как сделать связь между query и dbgrid>datasource>query? ( а то вообще печально, только с одной query работал, или так же как и с Table?
|
#15
|
|||
|
|||
эхушки, несоответствие типов пишит, IDych убрал птомучт счетчик, хоть эт прально сделал?
|