|
SQLite. Как вызвать ошибку в дополнительной (собственной) функции?
|
|||
---|---|---|---|
#18+
При вызове функции sqlite3_result_error, база данных не останавливаает выполнение запроса с генерацией ошибки, а просто не выводит строку в результирующий датасет (я пробовал на одной строке, SELECT fn1(1)). А надо, так как я этими функциями сделал арифметику без потерь точности. И за подобный результат мне просто открутят голову. Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25.
... |
|||
:
Нравится:
Не нравится:
|
|||
21.09.2009, 14:05 |
|
SQLite. Как вызвать ошибку в дополнительной (собственной) функции?
|
|||
---|---|---|---|
#18+
В чем смотрите? В шелле sqlite3 ваша функция должна выдавать ошибку. Вероятно, вы просто теряете сообщение об ошибке. ... |
|||
:
Нравится:
Не нравится:
|
|||
21.09.2009, 15:32 |
|
SQLite. Как вызвать ошибку в дополнительной (собственной) функции?
|
|||
---|---|---|---|
#18+
Ошибку я получаю с помощью sqlite3_errmsg , если sqlite3_prepare()!=SQLITE_OK . И если в синтаксисе запроса допустить ошибку, то ошибка выводится. Вы меня натолкнули на мысль, что возможно ошибку надо проверять после каждого вызова sqlite3_step . Вечером проверю. ... |
|||
:
Нравится:
Не нравится:
|
|||
21.09.2009, 15:38 |
|
SQLite. Как вызвать ошибку в дополнительной (собственной) функции?
|
|||
---|---|---|---|
#18+
Алексей VNОшибку я получаю с помощью sqlite3_errmsg , если sqlite3_prepare()!=SQLITE_OK . И если в синтаксисе запроса допустить ошибку, то ошибка выводится. Вы меня натолкнули на мысль, что возможно ошибку надо проверять после каждого вызова sqlite3_step . Вечером проверю. sqlite3_prepare не выполняет запрос, а только подготавливает его. Разумеется, эта функция не может определить ошибки этапа выполнения запроса :-) ... |
|||
:
Нравится:
Не нравится:
|
|||
21.09.2009, 20:11 |
|
SQLite. Как вызвать ошибку в дополнительной (собственной) функции?
|
|||
---|---|---|---|
#18+
Разобрался. Sqlite3_step возвращает значения 100 (Есть строка) и 101 (Конец данных). Если происходит ошибка, то возвращаемое значение 1. Но это только для первого выполнения! После вызова sqlite3_reset, sqlite3_step возвращает 0 (Есть строка), 1 (Нет строки), но и для ошибки тоже 1. И соответственно невозможно понять, это конец данных или ошибка, так как sqlite3_errno - возвращает значение аналогичное sqlite3_step, а sqlite3_error возвращает "Unknown error" даже если нет ошибки. В общем, самым простым и надежным решением было не использовать sqlite3_reset, а повторно вызывать sqlite3_prepare. Тогда с возвращаемыми значениями ошибок нет. ... |
|||
:
Нравится:
Не нравится:
|
|||
22.09.2009, 16:07 |
|
|
start [/forum/topic.php?fid=54&msg=36208638&tid=2009429]: |
0ms |
get settings: |
10ms |
get forum list: |
13ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
63ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
40ms |
get tp. blocked users: |
1ms |
others: | 331ms |
total: | 478ms |
0 / 0 |