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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 05.09.2017, 12:21
Ekler1 Ekler1 вне форума
Новичок
 
Регистрация: 12.06.2017
Сообщения: 90
Версия Delphi: RAD Studio XE7
Репутация: 10
По умолчанию Перенос строки из одной таблицы в другую

Может кто кодом поделится (если есть, конечно )
У меня в одной базе данных (Access) две таблицы, они одинаковые отображаются в dbgrid1 и dbgrid2 в первом гриде данные заполняются, в второй грид надо переносить записи из первого которые уже не нужны, ну тоесть из таблицы 1 в таблицу 2 по кнопке
Изображения
Тип файла: png Безымянный.png (119.3 Кбайт, 8 просмотров)
Ответить с цитированием
  #2  
Старый 05.09.2017, 12:28
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

Use Append/Post на втором наборе.
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #3  
Старый 05.09.2017, 15:17
Ekler1 Ekler1 вне форума
Новичок
 
Регистрация: 12.06.2017
Сообщения: 90
Версия Delphi: RAD Studio XE7
Репутация: 10
По умолчанию не фарт(

Код:
procedure TForm2.Button3Click(Sender: TObject);
begin
try
form2.ADOQuery2.SQL.Clear;
form2.ADOQuery2.SQL.Add('INSERT INTO zakazKLGOTOV SELECT * FROM ZakazKL');
form2.ADOQuery2.ExecSQL;
form2.ADOQuery1.SQL.Clear;
form2.ADOQuery1.SQL.Add('SELECT * FROM ZakazKLGOTOV');
form2.ADOQuery1.Active:=True;
except
on e:Exception do
end;

Нашел вот такой способ,под себя подправил, по описанию для чего - подходит. Вот только не работает(
Ответить с цитированием
  #4  
Старый 07.09.2017, 13:27
Ekler1 Ekler1 вне форума
Новичок
 
Регистрация: 12.06.2017
Сообщения: 90
Версия Delphi: RAD Studio XE7
Репутация: 10
По умолчанию (((

Может кто поможет сделать это все без SQL, сил шарить просторы интернета уже нету(
Ответить с цитированием
  #5  
Старый 07.09.2017, 16:48
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Оффтоп:

А чем помочь-то, когда задача не ясна, один туман: перенести запись из одной таблицы в другую целиком или отдельные значения ячеек, непонятки, нужен образец требуемого действия
Ответить с цитированием
  #6  
Старый 08.09.2017, 03:23
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,003
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну, например так:
Код:
ADOQuery2.Append;
For I := 0 To ADOQuery1.Fields.Count-1 Do
  ADOQuery2.Fields[i].Value := ADOQuery1.Fields[i].Value;
ADOQuery2.Post;
Это если кол-во и порядок полей одинаков и нет BLOB полей + надо сделать ADOQuery2 редактируемым. Если хоть одно условие не выполняется, то надо больше информации. Что-то всегда можно придумать.
Ответить с цитированием
  #7  
Старый 08.09.2017, 09:11
Ekler1 Ekler1 вне форума
Новичок
 
Регистрация: 12.06.2017
Сообщения: 90
Версия Delphi: RAD Studio XE7
Репутация: 10
По умолчанию

Цитата:
Сообщение от lmikle
Ну, например так:
Код:
ADOQuery2.Append;
For I := 0 To ADOQuery1.Fields.Count-1 Do
  ADOQuery2.Fields[i].Value := ADOQuery1.Fields[i].Value;
ADOQuery2.Post;
Это если кол-во и порядок полей одинаков и нет BLOB полей + надо сделать ADOQuery2 редактируемым. Если хоть одно условие не выполняется, то надо больше информации. Что-то всегда можно придумать.

Пытаюсь с твоим кодом выдает компилятор:
[dcc32 Error] Unit2.pas(76): E2003 Undeclared identifier: 'I'

Код:
procedure TForm2.Button3Click(Sender: TObject);
begin
form11.ADOQuery1.Append;
For I := 0 To form2.ADOQuery1.Fields.Count-1 Do
  form11.ADOQuery1.Fields[i].Value := form2.ADOQuery1.Fields[i].Value;
form11.ADOQuery1.Post;
end;

Что я не так наделал?
Ответить с цитированием
  #8  
Старый 08.09.2017, 09:14
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

У..у, man...

var I: Integer;
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #9  
Старый 08.09.2017, 09:41
Ekler1 Ekler1 вне форума
Новичок
 
Регистрация: 12.06.2017
Сообщения: 90
Версия Delphi: RAD Studio XE7
Репутация: 10
По умолчанию

Цитата:
Сообщение от NumLock
У..у, man...

var I: Integer;
уже попробывал так, компилятор работает, но когда выделяешь запись и нажимаешь на кнопку перенести появляется окно "Field 'Код' cannot be modified" Что ему там не нравится? (Поле код - счетчик)
Ответить с цитированием
  #10  
Старый 08.09.2017, 11:32
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

Ну "Undeclared identifier" то исчез А поле всегда можно исключить внутри цикла.
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #11  
Старый 08.09.2017, 12:05
Ekler1 Ekler1 вне форума
Новичок
 
Регистрация: 12.06.2017
Сообщения: 90
Версия Delphi: RAD Studio XE7
Репутация: 10
По умолчанию

Цитата:
Сообщение от NumLock
Ну "Undeclared identifier" то исчез А поле всегда можно исключить внутри цикла.

Код:
procedure TForm2.Button3Click(Sender: TObject);
var I:integer;
begin
form11.ADOQuery1.Append;
For I := 0 To form2.ADOQuery1.Fields.Count-1 Do
  form11.ADOQuery1.Fields[i].Value := form2.ADOQuery1.Fields[i].Value;
form2.adoquery1.delete;
fieldbyname('Код').value:=Fields[i]
form11.ADOQuery1.Post;
end;
Так надо код подредактировать?

Последний раз редактировалось lmikle, 08.09.2017 в 18:44.
Ответить с цитированием
  #12  
Старый 08.09.2017, 12:12
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

Применить условный оператор if.
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #13  
Старый 08.09.2017, 15:42
Ekler1 Ekler1 вне форума
Новичок
 
Регистрация: 12.06.2017
Сообщения: 90
Версия Delphi: RAD Studio XE7
Репутация: 10
По умолчанию

Цитата:
Сообщение от NumLock
Применить условный оператор if.
как его правильно написать под этот код?
Код:
procedure TForm2.Button3Click(Sender: TObject);
var I:integer;
begin
form11.ADOQuery1.Append;
For I := 0 To form2.ADOQuery1.Fields.Count-1 Do
  form11.ADOQuery1.Fields[i].Value := form2.ADOQuery1.Fields[i].Value;
form11.ADOQuery1.Post;
end;
я уже всю голову себе сломал(
Ответить с цитированием
  #14  
Старый 08.09.2017, 18:46
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,003
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от Ekler1
как его правильно написать под этот код?
...
я уже всю голову себе сломал(

Код:
procedure TForm2.Button3Click(Sender: TObject);
var I:integer;
begin
form11.ADOQuery1.Append;
For I := 0 To form2.ADOQuery1.Fields.Count-1 Do
  if form11.ADOQuery1.Fields[i].FieldName <> 'Код' Then
    form11.ADOQuery1.Fields[i].Value := form2.ADOQuery1.Fields[i].Value;
form11.ADOQuery1.Post;
end;

PS. Может все-таки книжку какую умную почитать сначала, а потом уже программировать?
Ответить с цитированием
Этот пользователь сказал Спасибо lmikle за это полезное сообщение:
Ekler1 (11.09.2017)
  #15  
Старый 11.09.2017, 08:57
Ekler1 Ekler1 вне форума
Новичок
 
Регистрация: 12.06.2017
Сообщения: 90
Версия Delphi: RAD Studio XE7
Репутация: 10
По умолчанию

Цитата:
Сообщение от lmikle
Код:
procedure TForm2.Button3Click(Sender: TObject);
var I:integer;
begin
form11.ADOQuery1.Append;
For I := 0 To form2.ADOQuery1.Fields.Count-1 Do
  if form11.ADOQuery1.Fields[i].FieldName <> 'Код' Then
    form11.ADOQuery1.Fields[i].Value := form2.ADOQuery1.Fields[i].Value;
form11.ADOQuery1.Post;
end;

PS. Может все-таки книжку какую умную почитать сначала, а потом уже программировать?
Спасибо, работает на ура! Только почему-то строка копируется из таблицы 1 в таблицу 2, было бы не плохо если бы удалялась из первой таблицы
P.S. Книги начал читать)
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter