Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.02.26;
Скачать: CL | DM;

Вниз

Глючат запросы!!!   Найти похожие ветки 

 
Святослав ©   (2006-02-13 01:26) [0]

Есть текстовый, из него быстро выбираются данные и делаются SQL запросы (типа обновить, вставить) с компоненом TQuyre !!! 800 запросов проходит успешно 801 вылетает!!! каждый раз разные системные ошибки!!!
У меня подозрение что каждый запрос идет независимым процессом, в итоге происходит что-то типа переполнение стека!
Вопрос: можно узнать, готова ли BDE принимать запросы?
Если я не прав, объясните пожалуйста механизм обработки  SQL запросов в BDE


 
atruhin ©   (2006-02-13 04:00) [1]

Попробуй после каждой сотни запросов сделать COMMIT


 
Vlad ©   (2006-02-13 09:03) [2]


> atruhin ©   (13.02.06 04:00) [1]
> Попробуй после каждой сотни запросов сделать COMMIT


А разве Paradox поддерживает транзакции? :-)


 
SkyRanger ©   (2006-02-13 09:06) [3]

Ну коммит ему поможет если он открывал транзакцию, а так по идее все должно работать... Попробуй просто с помощью компонента таймера ограничить количество запросов. Скорее всего BDE захлебывается данными... Хотя я могу быть и не прав...


 
Desdechado ©   (2006-02-13 12:46) [4]

> каждый раз разные системные ошибки!!!
список ошибок в студию

> подозрение что каждый запрос идет независимым процессом
если явноне стартовал транзакцию, то один запрос - одна транзакция


 
msguns ©   (2006-02-13 13:04) [5]

В парадоксе нет транзакций. При большом количестве изменений может быть переполнение таблиц блокировок (*.lck). "Лечится" закрытием БД и открытием по новому.

>Вопрос: можно узнать, готова ли BDE принимать запросы?

 Она всегда готова принимать "запросы". А вот готов ли принимать их "сервер" - это вопрос

>Если я не прав, объясните пожалуйста механизм обработки  SQL запросов в BDE

 В BDE есть механизм обработки сиквель-запросов, но нет механизма выполнения их. "Механизм" заключается в том, что текст запроса проверяется на "политкорректность" стандарту SQL (Local SQL в понимании BDE) и  либо передается ядру для непосредственного доступа к "родным" форматам (dBase,Paradox), либо интерпретируется в SQL "чужого" формата и передается соответствующим библиотекам поддержки собственно "чужих" серверов для непосредственного исполнения SQL-серверами.

Что касется парадокса, то из-за отсутствия централизованного аппарата доступа в данным (сервера) "синхронизация" доступа выполняется через рабочие файлы: *.net (синхронизация пользователей), *.lck (синхронизация таблиц). Такой механизм, естественно, ничего "не знает" о транзакциях и их воздействиии друг на друга. Поэтому для создния более-менее ответственных многопользовательских БД либо разрабатывают трехзвенки с сохранением собственно формата, либо переходят на более надежные и функциональные агрегаты типа Interbase, MSSQL, Oracle..


 
Святослав ©   (2006-02-13 13:11) [6]

Всем СПАСИБО!!!
Теперь ясно что делать дальше…



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

Текущий архив: 2006.02.26;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.054 c
2-1139561331
worldmen
2006-02-10 11:48
2006.02.26
Изменение формата даты.


2-1139833368
Делфёст
2006-02-13 15:22
2006.02.26
Шифровка поля


15-1138016360
Nous Mellon_
2006-01-23 14:39
2006.02.26
Сайт php.ru


1-1138179162
bg8
2006-01-25 11:52
2006.02.26
OnKeyDown


15-1137225791
ferr
2006-01-14 11:03
2006.02.26
XP64