Форум Flasher.ru
Ближайшие курсы в Школе RealTime
Список интенсивных курсов: [см.]  
  
Специальные предложения: [см.]  
  
 
Блоги Правила Справка Пользователи Календарь Сообщения за день
 

Вернуться   Форум Flasher.ru > Flash > Flash Приложения: AIR, Zinc и тд.

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему Ответ
Старый 24.11.2011, 21:09
BornTOFree вне форума Посмотреть профиль Отправить личное сообщение для BornTOFree Найти все сообщения от BornTOFree
  № 1  
Ответить с цитированием
BornTOFree

Регистрация: Oct 2010
Сообщений: 85
По умолчанию Редактирование полей SQLite в теле цикла [AIR]

Есть необходимость редактировать сразу ряд полей базы данных, пытаюсь сделать так:
Код AS3:
for(var i:int = 0; i < arrItem.length; i++) {
     edit(arrTitle[i], arrDes[i], arrID[i]);
}
public function edit(title:String, des:String, id:int):void {
 
	stmtControl.text ="UPDATE sectionLink SET title='"+title+"', description='"+des+"' WHERE id='"+id+"'";
	stmtControl.execute();
 
}
пишет ошибку
Цитата:
Error #3110: Operation cannot be performed while SQLStatement.executing is true.
ссылаясь на
Цитата:
stmtControl.text ="UPDATE sectionLink SET title='"+title+"', description='"+des+"' WHERE id='"+id+"'";
Если писать с условием
Код AS3:
public function edit(title:String, des:String, id:int):void {
 
	if ( !stmtControl.executing ){
		stmtControl.text ="UPDATE sectionLink SET title='"+title+"', description='"+des+"' WHERE id='"+id+"'";
		stmtControl.execute();
	}
 
}
То запись в базу выполняется только с первой итерации цикла, потом условие обрубает доступ к stmtControl.
Почему так происходит и как можно исправить.

Старый 25.11.2011, 13:08
DaFive вне форума Посмотреть профиль Отправить личное сообщение для DaFive Посетить домашнюю страницу DaFive Найти все сообщения от DaFive
  № 2  
Ответить с цитированием
DaFive
 
Аватар для DaFive

Регистрация: May 2008
Адрес: {0,0}
Сообщений: 754
Записей в блоге: 1
Отправить сообщение для DaFive с помощью ICQ
У вас коннект к базе асинхронный походу. Нужно дождаться выполнения запроса к таблице. С синхронным бы такого не произошло. Ну и id в кавычки не обязательно, если INT, а название таблицы лучше в тильды ``.
__________________
Кодинг, багинг, алгоритминг. me @

Старый 25.11.2011, 18:42
BornTOFree вне форума Посмотреть профиль Отправить личное сообщение для BornTOFree Найти все сообщения от BornTOFree
  № 3  
Ответить с цитированием
BornTOFree

Регистрация: Oct 2010
Сообщений: 85
асинхронный
Цитата:
Нужно дождаться выполнения запроса к таблице.
Да, действительно, но тогда будет ужасно медленно работать.

Старый 25.11.2011, 20:21
DaFive вне форума Посмотреть профиль Отправить личное сообщение для DaFive Посетить домашнюю страницу DaFive Найти все сообщения от DaFive
  № 4  
Ответить с цитированием
DaFive
 
Аватар для DaFive

Регистрация: May 2008
Адрес: {0,0}
Сообщений: 754
Записей в блоге: 1
Отправить сообщение для DaFive с помощью ICQ
Код AS3:
var counter:int = 1;
edit(arrTitle[counter], arrDes[counter], arrID[counter]);
Почему? будет так же работать.
addEventListener(SQLEvent.RESULT, handler);
И в хэндлере:
Код AS3:
counter++;
edit(counter);
__________________
Кодинг, багинг, алгоритминг. me @

Создать новую тему Ответ Часовой пояс GMT +4, время: 11:30.
Быстрый переход
  « Предыдущая тема | Следующая тема »  

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

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


 


Часовой пояс GMT +4, время: 11:30.


Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2024, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.