|
VFPOLEDB, точка облома SELECT'а
|
|||
---|---|---|---|
#18+
Периодически подкачиваю dbf'ку на MSSQL 2012 c помощью VFPOLEDB. Создан linked server по имени FOXDBF, отдается команда INSERT, которая сводится к Код: sql 1.
Однако в dbf-ке могут возникать ошибки, и select не дорабатывает до конца, при этом транзакция откатывается, а я получаю сообщение вроде Код: sql 1. 2. 3.
Это бывает, например, когда в поле region (N 2) вставляют значение 160, и в поле вместо числа оказывается "переполнение", и т.п. Вопрос следующий - как понять, в какой строке таблицы на 500.000 строк сбился select, чтобы хотя бы продиагностировать ошибку? Есть ли возможность опросить какие-то функции/переменные провайдера ? Пока что просто переспрашиваю select в окне SSMS, и смотрю, за какой последней "хорошей" строкой умер запрос, но это хатратно и неудобно. ... |
|||
:
Нравится:
Не нравится:
|
|||
12.08.2014, 13:05 |
|
VFPOLEDB, точка облома SELECT'а
|
|||
---|---|---|---|
#18+
Предусмотрите это сразу же в запросе. ... |
|||
:
Нравится:
Не нравится:
|
|||
12.08.2014, 15:53 |
|
VFPOLEDB, точка облома SELECT'а
|
|||
---|---|---|---|
#18+
dayone, Я периодически сталкиваюсь с точно такой же проблемой. Выкручиваюсь следующим образом: перед тем как залить таблицу на сервер, избавляюсь от этих долбаных звездочек(переполнений) в числовых полях, в вашем случае так: Код: sql 1.
... |
|||
:
Нравится:
Не нравится:
|
|||
12.08.2014, 16:46 |
|
|
start [/forum/topic.php?fid=41&fpage=30&tid=1582581]: |
0ms |
get settings: |
8ms |
get forum list: |
11ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
33ms |
get topic data: |
11ms |
get forum data: |
2ms |
get page messages: |
41ms |
get tp. blocked users: |
2ms |
others: | 11ms |
total: | 125ms |
0 / 0 |