Главная страница
    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.034 c
1-1099990169
race1
2004-11-09 11:49
2004.11.21
caption


3-1098196764
Kat
2004-10-19 18:39
2004.11.21
запросом как вывести год из этого поля!?


4-1097351708
AlexeyM
2004-10-09 23:55
2004.11.21
размер процесса


3-1098502374
Vasis
2004-10-23 07:32
2004.11.21
Выборка по дате


14-1099766439
SteelMan
2004-11-06 21:40
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
Английский Французский Немецкий Итальянский Португальский Русский Испанский