Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Основная";
Текущий архив: 2004.11.21;
Скачать: [xml.tar.bz2];

Вниз

Произошли ошибки во время выполнения многошаговой операции   Найти похожие ветки 

 
TechnoDreamer   (2004-11-02 03:29) [0]

Собственно прога выдает во время рунтайма следующее сообщение:
"Произошли ошибки во время выполнения многошаговой операции. Проверьте значение всех состояний". Происходит во время рекурсивной функции, насколько я вижу только в тех случаях где рекурсия большая. Я прав? Кто нибуть сталкивался?
Что делать? Может есть какая директива компилятору, типа там, стек увеличить или еще что, которая влияет на это?
Или придется убирать рекурсию? Жалко было бы, такая аккуратная функция получилась :-(((


 
©   (2004-11-02 03:58) [1]

А код привести можно.


 
Defunct ©   (2004-11-02 04:30) [2]

> "Произошли ошибки во время выполнения многошаговой операции. Проверьте значение всех состояний"

У тебя что русский Delphi? Неужели прямо так и пишет.


 
Fay ©   (2004-11-02 06:36) [3]

Переделай в цикл.


 
KSergey ©   (2004-11-02 08:19) [4]

Очеь похоже на сообщение от ADO... Оно используется?


 
TechnoDreamer   (2004-11-02 18:29) [5]

2R: Код довольно большой и связан с другими кусками.
2Fay: Видимо придется,хотя...
2KSergey: Да, адо используется, подскажешь в связи с чем ошибка?

Вообще, код делает следующее:
Есть дерево (TTreeView) и база на Access через ADO, в дереве хранятся названия категорий (возможны и подкатегории) и элементов, т.е. оно связано с базой (там две таблицы: категории и элементы, одно из полей название категории или элемента).
Рекурсивная функция для удаления категории, т.е. она смотрит, если нет дочерних элементов то удаляется запись в базе, и соответствующий элемент TTreeNode, в противном случае удаляется рекурсивно подкатегории и элементы.
На небольших ветках дерева работает прекрасно, а вот на более больших возникает эта ощибка (2Defunct, да так прям и пишет, это винда пишет, а не дельфи, и судя по постингу KSergey это пишет ADO).


 
TechnoDreamer   (2004-11-02 18:29) [6]

2R: Код довольно большой и связан с другими кусками.
2Fay: Видимо придется,хотя...
2KSergey: Да, адо используется, подскажешь в связи с чем ошибка?

Вообще, код делает следующее:
Есть дерево (TTreeView) и база на Access через ADO, в дереве хранятся названия категорий (возможны и подкатегории) и элементов, т.е. оно связано с базой (там две таблицы: категории и элементы, одно из полей название категории или элемента).
Рекурсивная функция для удаления категории, т.е. она смотрит, если нет дочерних элементов то удаляется запись в базе, и соответствующий элемент TTreeNode, в противном случае удаляется рекурсивно подкатегории и элементы.
На небольших ветках дерева работает прекрасно, а вот на более больших возникает эта ощибка (2Defunct, да так прям и пишет, это винда пишет, а не дельфи, и судя по постингу KSergey это пишет ADO).


 
KSergey ©   (2004-11-03 12:57) [7]

Однозначно тут сказать очень сложно.
Советую предпринять след. шаги:

1.Как я понимаю - все делается методами Delete/Post и т.п. Можно перейти на SQL-запросы на удаление/обновление. Во всяком случае эту проблему это решит однозначно.

2.Какая БД используется? Для MS SQL могу рассказать, про другие -не знаю. (к стати, приличные люди сразу это пишут, в вопросе)

3.В любом случае советую почитать все три части от
http://www.delphikingdom.com/asp/viewitem.asp?catalogid=408


 
TechnoDreamer   (2004-11-03 18:46) [8]

//1.Как я понимаю - все делается методами Delete/Post и т.п. Можно перейти на SQL-запросы на удаление/обновление. Во всяком случае эту проблему это решит однозначно.//

Да, вы правы.

//2.Какая БД используется? Для MS SQL могу рассказать, про другие -не знаю. (к стати, приличные люди сразу это пишут, в вопросе)//
Я говорил:
//Есть дерево (TTreeView) и база на Access через ADO//


 
KSergey ©   (2004-11-04 06:53) [9]

> Я говорил:
> //Есть дерево (TTreeView) и база на Access через ADO//

Прошу прощения, просмотрел.
Тогда, думаю, приведенная мною ссылка должна помочь - там именно про Access и очень много. (только читать все 3 части)


 
Erik1 ©   (2004-11-04 10:31) [10]

Вобщето стоит перейти на DOA, это избавить от дополнительной прослойуи в лице ADO и повысит скорость работы. Я советую компоненты diamond www.islamov.com Кое что даже сам правил, но назнаю включил ли он это в свою версию.



Страницы: 1 вся ветка

Форум: "Основная";
Текущий архив: 2004.11.21;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.47 MB
Время: 0.038 c
1-1099749674
Pavia
2004-11-06 17:01
2004.11.21
Редактор мат формул.


14-1099913616
ОлегЪ
2004-11-08 14:33
2004.11.21
Инитересный ресурс


3-1098685941
Nikolay_S
2004-10-25 10:32
2004.11.21
Microsoft OLE DB Provider for Oracle


14-1099486160
Shiza
2004-11-03 15:49
2004.11.21
Total Commander


3-1098430766
Aser
2004-10-22 11:39
2004.11.21
Как выбрать все из таблицы 1 и все из таблицы 2





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский