Главная страница
    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.033 c
1-1099992632
Stanislav
2004-11-09 12:30
2004.11.21
TMemoryStream В чем отличее методов


6-1095319344
Vovik
2004-09-16 11:22
2004.11.21
Net News Transport Protocol


4-1097321602
volser
2004-10-09 15:33
2004.11.21
Стандартные иконки


4-1097472609
MegaVolt
2004-10-11 09:30
2004.11.21
Что за структуру создаёт CreatePolygonRgn


4-1097326582
CAMCOH
2004-10-09 16:56
2004.11.21
Програмное изменение "Do not show hidden files"





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