|
0 / 0 / 0
Регистрация: 17.07.2012
Сообщений: 31
|
||||||||||||||||
FoxPro Многопоточность и BDE17.10.2015, 16:01. Показов 1529. Ответов 6
Метки нет (Все метки)
Доброе время суток, уважаемые форумчане. Назрела такая проблема: возникла необходимость сравнить две базы данных 1С (состав - *.dbf, *.cdx). Построение списка файлов *.dbf в одной и в другой базе решил сделать в двух потоках, которые запускаются одновременно. Среди прочего, в этих потоках определяется количество записей в каждой таблице сравниваемых баз данных. При запуске потоков выполняется только один, а второй попросту виснет без каких-либо исключениях. Сделал пошаговую трассировку - и действительно, второй поток виснет на инструкции
По ссылке http://www.loginovprojects.ru/... deproblems ознакомился со статьёй и обратил внимание на следующее: " Многопоточное приложение виснет при работе с таблицами базы данных. Проблема возникает из-за того, что во всех потоках по умолчанию используется объект TSession с именем "Default". Похоже, что в недрах BDE какие-то ресурсы защищаются от одновременного доступа с помощью критической секции, либо мьютекса. Перед выполнением SQL-запроса происходит захват объекта синхронизации, а после выполнения запроса захват данного объекта снимается. Если при выполнении запроса произойдет исключение, то снятие блокировки может не произойти (это бывает не всегда, а только в некоторых ситуациях, вероятно, где-то по ошибке пропущен оператор TRY..FINALLY), и выполнение любого запроса из параллельного потока приведет к его зависанию, т.к. он будет вечно ждать снятия блокировки. Для решения данной проблемы следует для каждого потока создавать свой объект TSession с уникальным именем SessionName, и назначать SessionName всем используемым в данном потоке DB-компонентам. SessionName лучше сделать глобально уникальным (это предотвратит зависание, если в качестве объекта синхронизации используется именованный мьютекс) ". В каждом потоке динамически создаю объекты Tsession и TTable, однако результат тот же. Когда-то довольно часто работал с BDE, но компонентами TDataBase и TSeesion пользовался редко, практически позабыл про них. Может я что-то не так делаю (естественно, иначе работало бы ). Помогите, пожалуйста. Заранее благодарен.Привожу код. Первый поток:
0
|
||||||||||||||||
| 17.10.2015, 16:01 | |
|
Ответы с готовыми решениями:
6
Ремонт Прошу совета ПММ Krona BDE 4507 EU, ПММ Krona BDE 4507 EU Ошибка Е3 исчезла после чистки BDE BDE |
| 17.10.2015, 17:27 | ||||||
|
1. ну сравнить базы можно и не таким способом
2. я не вижу динамическое создание ни TTable, ни TSession вот так надо создавать
0
|
||||||
|
0 / 0 / 0
Регистрация: 17.07.2012
Сообщений: 31
|
||||||
| 17.10.2015, 17:58 [ТС] | ||||||
|
Создание компонентов происходит в методе Execute потоков (если обратите внимание на мой код, начиная со строчки 70...). Согласен, что при создании компонента при отсутствии желания указывать на родителя лучше использовать переменную Self, а не nil, как в моём случае (хотя (могу ошибаться ) эффект один и тот же).
Если обратите внимание на процедуру GetAllFilesDB(DirPath1) (что касается первого потока, во втором всё аналогично), то увидите, что функция анализирует необходимую папку (переменная DirPath1, DirPath2) на наличие файлов *.dbf и загружает их список в память... Имена таблиц (полный путь к таблицам) меняются благодаря присвоения соответствующему свойству компонента TTable значения переменной sRec.Name типа TSearchRec... Но хватит об этом... Самое смешное - экспериментировал с кодом на работе в результате чего один из потоков сделал не автоматически запускающимся
Одного не могу понять - почему так? Я согласен, что необходимо создавать разные сессии, если обращение к одной и той же базе данных осуществляется из разных потоков. Однако мои потоки работают с базами, физически расположенными в разных директориях, а значит расцениваются как совершенно разные. Буду благодарен за объяснение.
0
|
||||||
|
0 / 0 / 0
Регистрация: 17.07.2012
Сообщений: 31
|
|
| 17.10.2015, 18:33 [ТС] | |
|
Кстати, Delphi автоматически генерирует объект Session в каждом приложении, которое работает с базами данных. И как было указано в статье, представленной выше, имеет имя default.
Скорее всего, если выполнять операции над базами данных в потоках (фактически отдельные приложения), объект TSession не создаётся, либо создаётся, но при количестве потоков более одного происходит конфликт имён (если имена не назначать явно - n-ное количество "default"). Если неправильно рассудил, исправьте. Добавлено через 53 секунды qwertehok, Добавлено через 3 минуты Два одновременных потока не жизненная необходимость, а скажем так "личный каприз". Идея же - существует две базы 1С 7.7 (практически от них отошли (прошлый век, скажем так))... 1С работает в файл-серверной архитектуре, то есть располагается на каком-то диске и расшарена. Всё руки не доходили склипать батник или что-то своими ручками в Делфи для резервного копирования (причём не только различных баз данных, но и важных документов и иных файлов). Так вот, у меня к примеру есть резервная копия базы 1С, но в ней не хватает записей за 2 дня (не было возможности сделать рез. копию, а пользователь при этом работал и вбивал данные). При возникновении проблемы с этой БД, я открываю её и резервную копию двухдневной давности в моей программе. Программа проходит по файлам *.dbf и формирует MD5-отпечаток. Если MD-5 отпечатки сравниваемых таблиц не равен, значит базы отличаются. Остаётся обратиться к нужной таблице и выяснить какие поля изменил и какие записи добавил пользователь и внести эти изменения в стабильно работающую базу данных. А про мою задумку и MS SQL можно по-подробнее.
0
|
|
|
3530 / 2270 / 279
Регистрация: 24.12.2010
Сообщений: 13,723
|
||
| 17.10.2015, 19:30 | ||
|
Делают-то они у тебя одно и тоже, но с разными исх.данными..
0
|
||
| 17.10.2015, 20:08 | |||
|
Flex_, ставь пользователю MS SQL (если база меньше 10 гигов то достаточно будет бесплатной версии), настраивай ежедневный бэкап (хочешь полный, хочешь с diff'ами) и не морочь голову с Delphi
И хочешь что бы у тебя все работало? Нет слов
0
|
|||
| 17.10.2015, 20:08 | |
|
Помогаю со студенческими работами здесь
7
Избавится от BDE BDE и SQL2012 BDE Admin запрос в BDE Работа с BDE Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2.
Задача: отобразить спецтехнику, которая на данный момент находится в ремонте.
Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
|
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
|
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|