Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
 Аватар для Mr.Sandman
42 / 59 / 15
Регистрация: 19.12.2011
Сообщений: 552

Format Update

19.06.2012, 12:15. Показов 1264. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
try
BDForm.tW.StartTransaction;
BDForm.s.SQL.Clear;
//BDForm.s.SQL.Text :=Format('update auto_list set year=%s',[StrToDate(Edit1.Text)]);
BDForm.s.SQL.Text :=Format('update auto_list set probeg=%f',[StrToInt(Edit2.Text)]);
BDForm.s.SQL.Text :=Format('update auto_list set horses=%f',[StrToFloat(Edit3.Text)]);
BDForm.tW.Commit;
BDForm.s.SQL.EndUpdate;
finally
//BDForm.tw.Active:=false;
BDForm.s.Transaction.Active:=false;
end;
Так перезаписываю данные в бд (auto_list), но в резкльтате ошибка 'Transaction is active'
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.06.2012, 12:15
Ответы с готовыми решениями:

Date Format Access
Здравствуйте Извечная проблема с системной датой и Access Помогите исправить я копирую из одной таблицы в другую ...

#define PRINT(format,x) printf("x = %format\n",x)
#include <stdio.h> #include <limits.h> #define PRINT(format,x) printf("x = %format\n",x) int integer = 5; char character = '5'; ...

DataGrid update ПРОБЛЕМА: Key column information is insufficient or incorect. Too many rows were affected by update
Привет всем ! В Вижуал Басик6 на форме имею ДатаГрид с информацией из Аксцессс 2000. Соединение - АДО. Пропертями усе установленно...

11
 Аватар для rdama
569 / 292 / 12
Регистрация: 28.01.2011
Сообщений: 1,326
19.06.2012, 12:20
А почему комит у вас в теле транзакции?
А не за ее пределами?
Что за СУБД?
Комит автоматически завершает текущую транзакцию. Если конечно не работаете в паралелях. Но это не ваш случай.
0
 Аватар для Mr.Sandman
42 / 59 / 15
Регистрация: 19.12.2011
Сообщений: 552
19.06.2012, 12:23  [ТС]
хоть с комитом хоть без, все равно transaction is active. Хотя по логике она дожна завершаться
0
 Аватар для rdama
569 / 292 / 12
Регистрация: 28.01.2011
Сообщений: 1,326
19.06.2012, 13:07
С какой СУБД вы работаете?
0
 Аватар для arni
914 / 879 / 62
Регистрация: 06.01.2010
Сообщений: 2,367
Записей в блоге: 6
20.06.2012, 00:06
если так?
Delphi
1
2
3
4
5
6
7
8
9
try
  if not BDForm.tW.Active then
    BDForm.tW.StartTransaction;
  BDForm.s.SQL.Text :=Format('update auto_list set probeg=%f',[StrToInt(Edit2.Text)]);
  BDForm.s.SQL.Text :=Format('update auto_list set horses=%f',[StrToFloat(Edit3.Text)]);
  BDForm.tW.Commit;
except
  BDForm.s.Transaction.Rollback;
end;
- выкинул шлак;
- обращаю внимание на то, что у вас нет собственно выполнения команды: вы сформировали sql-запрос, но нигде его не вызвали;
- более того, вы сформировали 2 запроса, и вызывать их как-бы надо дважды. Либо, что вероятнее, нужен 1 запрос на обновление, но двух полей. Тогда запросы вообще неверные.
- более того, update без where попахивает недопониманием сути запроса.
0
 Аватар для Mr.Sandman
42 / 59 / 15
Регистрация: 19.12.2011
Сообщений: 552
26.06.2012, 12:35  [ТС]
Так решил
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
procedure TEdForm.Save;
begin
  try
    BDForm.tW.StartTransaction;
    BDForm.s.SQL.Clear;
 
    //BDForm.s.SQL.Text :=Format('update auto_list set year=%f where id=%d',[StrToDate(Edit1.Text), ID]);
    //BDForm.s.ExecQuery;
 
    BDForm.s.SQL.Text := Format('update auto_list set probeg=%d where id=%d',[StrToInt(Edit2.Text), ID]);
    BDForm.s.ExecQuery;
 
    BDForm.s.SQL.Text := Format('update auto_list set horses=%d where id=%d',[StrToInt(Edit3.Text), ID]);
    BDForm.s.ExecQuery;
 
 
    BDForm.tW.Commit;
 
    BDForm.q.Active:=false;
    BDForm.q.Active:=true;
    BDForm.q.Open;
 
    bSave.Enabled := false;
 
  finally
    BDForm.tw.Active := false;
  end;
end;
Добавлено через 37 секунд
А как добавить или удалить строку?
0
 Аватар для arni
914 / 879 / 62
Регистрация: 06.01.2010
Сообщений: 2,367
Записей в блоге: 6
26.06.2012, 13:41
Цитата Сообщение от Gleban38 Посмотреть сообщение
Так решил
строки №5 и №20 бессмысленны в контексте следующих строк
0
 Аватар для Mr.Sandman
42 / 59 / 15
Регистрация: 19.12.2011
Сообщений: 552
27.06.2012, 09:12  [ТС]
Строки 19 и 20 "передергивают" (обновляют) грид.
0
 Аватар для arni
914 / 879 / 62
Регистрация: 06.01.2010
Сообщений: 2,367
Записей в блоге: 6
27.06.2012, 09:44
Gleban38,
ну а 21 что делает после 20?
0
 Аватар для Mr.Sandman
42 / 59 / 15
Регистрация: 19.12.2011
Сообщений: 552
27.06.2012, 10:24  [ТС]
arni, 21
Delphi
1
BDForm.q.Open;
загружает в грид таблицу, однако без передергивания значения в гриде не меняются!
0
 Аватар для HyperZen
498 / 251 / 56
Регистрация: 16.06.2011
Сообщений: 904
27.06.2012, 11:08
Эти записи равнозначны, вот тебе про что...
Цитата Сообщение от Gleban38 Посмотреть сообщение
Delphi
1
2
BDForm.q.Active:=true;
BDForm.q.Open;
Зачем два раза делать одно и то же?

Добавлено через 1 минуту
+ строка 5 бессмысленна, потому как
Delphi
1
BDForm.s.SQL.Text:=
- перезаписывает запрос.
0
 Аватар для Mr.Sandman
42 / 59 / 15
Регистрация: 19.12.2011
Сообщений: 552
27.06.2012, 11:10  [ТС]
Все возможно
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.06.2012, 11:10
Помогаю со студенческими работами здесь

Дедлоки между update limit N и update по primary key
Добрый день! Столкнулся с дедлоками, хотелось бы послушать опытных товарищей как с этим быть. Описание: Есть табличка CREATE...

Не получается сделать Update (Update requires a valid InsertCommand)
Не получается сделать Update выдаёт ошибку, что делаю не так? В таблице только одно поле, оно строковое. public void...

Ошибка при Update "Update requires a valid InsertCommand when passed DataRow collection with new rows"
Доброго времени суток! Я в этом всем новичек и поэтому совсем не могу понять в чем ошибка. В общем, имеется вот такой код: ...

format.com
в описании параметров программы написано что она служит для форматирования для DOS. а где найти программу для форматирования для WIN?

Format$ ??
В чем отличие Format$ от Cstr ???


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru