Главная страница
    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.036 c
14-1099641955
d[D]E
2004-11-05 11:05
2004.11.21
Вертикальный DBGrid


3-1098869303
TolkoNachal
2004-10-27 13:28
2004.11.21
Различное выполнение query.last


4-1097440931
Прямой
2004-10-11 00:42
2004.11.21
Инсталяция в W2K и старше, Где Windows берет размер установленног


4-1097500329
TeNY
2004-10-11 17:12
2004.11.21
Как програмно нажать кнопку Enter через SendMessage


14-1099316076
Оля
2004-11-01 16:34
2004.11.21
Как отправить факс?





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский