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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 28.05.2015, 12:00
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию Цикл в таблице

Помогите разобраться с такой задачей, есть Edit в него пишется число (количество), по нажатии кнопки необходимо, что бы в ADODataSet добавилось количество записей равному указанному числу в Edit, так что бы в поле "Номер" последовательно происходила нумерация 1, 2, 3, и так до i:=StrToInt(Edit1.Text)
что то вроде этого
Код:
var
i: integer;
index: integer;
begin
  index:=0;
 i:=StrToInt(Edit1.Text);
for index:=0 to i do
DataModule2.ExDS.Insert;
DataModule2.ExDS.FieldValues['Номер экземпляра']:=index+1;
 DataModule2.ExDS.Post;
знаю код совершенно не правильный, но смысл я думаю понятен
Ответить с цитированием
  #2  
Старый 28.05.2015, 13:05
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Не занимайтесь хернёй, делайте insert/update таблицы через запрос.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
  #3  
Старый 28.05.2015, 13:11
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию

А как такой запрос написать для ADODataSet?
Ответить с цитированием
  #4  
Старый 28.05.2015, 14:13
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Никакой.
Надо писать запрос для ADOCommand, типа insert into table(...) values(...).
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
Этот пользователь сказал Спасибо M.A.D.M.A.N. за это полезное сообщение:
Brons14 (28.05.2015)
  #5  
Старый 28.05.2015, 14:36
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию

А можно подробнее, в инете не нашел информации как запрос писать в ADOCommand, я создал его, а дальше куда писать запрос и как, что бы по нажатии кнопки он добавлял записи определенного количества в ADODataSet
Ответить с цитированием
  #6  
Старый 28.05.2015, 20:00
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

твоя проблема в том, что ты не обрамил тело цикла в begin..end. Соотв. в цикле у тебя выполняется только первая команда.
Код:
for index:=0 to i do
begin
  DataModule2.ExDS.Insert;
  DataModule2.ExDS.FieldValues['Номер экземпляра']:=index+1;
  DataModule2.ExDS.Post;
end;

Можно, конечно, добавлять запросами через ADOCommand (кстати, если не изменяет память, то подобный запрос можно выполнить и через ADOConnection, вроде у него есть метод ExecSQL), но с точки зрения выполняемых комманд это будет абсолютно тоже самое, только, в случае использования прямого запроса, надо будет еще и перечитать открытый DataSet. Тут надо смотреть что же тебе надо на самом деле.
Ответить с цитированием
Этот пользователь сказал Спасибо lmikle за это полезное сообщение:
Brons14 (28.05.2015)
  #7  
Старый 28.05.2015, 21:08
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию

А как реализовать это циклом? Мой код даже записи не добавляет
Ответить с цитированием
  #8  
Старый 28.05.2015, 22:11
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

А ты уверен, что не добавляет? В моей редакции должен. Просто другие компоненты, нацеленные на эту таблицу, просто не знают о том, что записи добавились. Надо их переоткрыть.
Ответить с цитированием
  #9  
Старый 28.05.2015, 22:42
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию

Не знаю пока, как сделать что бы каждой записи в поле Номер присваивалось значение, поэтому делаю для примера так
Код:
i:=StrToInt(Edit1.Text);
for index:=0 to i do
begin
  DataModule2.ExDS.Insert;
  DataModule2.ExDS.Post;
end;
код должен создать количество записей указанное в Edit, но так ни одной записи не добавляется, все проверил таблица указана верно
Ответить с цитированием
  #10  
Старый 28.05.2015, 23:20
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

https://ru.wikipedia.org/wiki/Insert_(SQL)
http://www.sql-tutorial.ru/ru/book_operator_insert.html
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
Этот пользователь сказал Спасибо M.A.D.M.A.N. за это полезное сообщение:
Brons14 (28.05.2015)
  #11  
Старый 28.05.2015, 23:34
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от Brons14
Не знаю пока, как сделать что бы каждой записи в поле Номер присваивалось значение, поэтому делаю для примера так
Код:
i:=StrToInt(Edit1.Text);
for index:=0 to i do
begin
  DataModule2.ExDS.Insert;
  DataModule2.ExDS.Post;
end;
код должен создать количество записей указанное в Edit, но так ни одной записи не добавляется, все проверил таблица указана верно

Проверь тип транзакции. Впечатление, что у тебя commit не проходит.
Ответить с цитированием
  #12  
Старый 28.05.2015, 23:44
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию

управление транзакциями вообще не применялось,
а по ADOCommand не нашел информации как его связать с таблицей и куда писать текст запроса, и я так понимаю он должен быть с параметром

Последний раз редактировалось Brons14, 28.05.2015 в 23:47.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter