|
Как "заснуть" на время внутри SPL?
|
|||
---|---|---|---|
#18+
Один из способов, как "заснуть" в середине хранимки или даже в клиентской программе, выполнить функцию integer sysmaster:yieldn() или integer sysmaster:yieldn( integer nseconds ). Обычно это функция "засыпает" на nseconds, но иногда эта функция может завершится раньше чем задано. Впрочем, в новых версиях Informix этого никогда не происходит, но даже если и произойдет функция вернет количество секунд, на которое реально было приостановлено выполнение. Оригинал статьи: How to sleep (or yield) for a fixed time in a stored procedure От себя: иногда это реально необходимо, особенно при работе вторичного сервера в режиме UPDATEBLE. В случае, когда данные обновляются через вторичку иногда необходима небольшая задержка, чтобы эта запись распространилась по всем нодам кластера через логические журналы и стала доступной другим юзерам. С уважением, Виктор ... |
|||
:
Нравится:
Не нравится:
|
|||
10.11.2012, 22:12 |
|
Как "заснуть" на время внутри SPL?
|
|||
---|---|---|---|
#18+
в 7.31 только system "sleep 1" ... |
|||
:
Нравится:
Не нравится:
|
|||
12.11.2012, 11:32 |
|
Как "заснуть" на время внутри SPL?
|
|||
---|---|---|---|
#18+
victor16, в доке про неё ни слова, посему непонятно, когда появилась. А что у неё внутри в вашей версии сервера? ... |
|||
:
Нравится:
Не нравится:
|
|||
12.11.2012, 11:39 |
|
Как "заснуть" на время внутри SPL?
|
|||
---|---|---|---|
#18+
АнатоЛой в доке про неё ни слова... это еще одна из многих недокументированных возможностей :-) АнатоЛой что у неё внутри ? У меня получилось создать в базе, отличной от sysmaster :-) Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15.
... |
|||
:
Нравится:
Не нравится:
|
|||
12.11.2012, 13:17 |
|
Как "заснуть" на время внутри SPL?
|
|||
---|---|---|---|
#18+
victor16, спасибо, ничего неожиданно нового :). ... |
|||
:
Нравится:
Не нравится:
|
|||
12.11.2012, 13:36 |
|
Как "заснуть" на время внутри SPL?
|
|||
---|---|---|---|
#18+
АнатоЛой, спасибо я и не претендовал на экстраординарность, надо же хоть как-то придать активность ветке :) ... |
|||
:
Нравится:
Не нравится:
|
|||
12.11.2012, 14:00 |
|
|
start [/forum/topic.php?fid=44&msg=38034497&tid=1607109]: |
0ms |
get settings: |
23ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
39ms |
get topic data: |
12ms |
get forum data: |
3ms |
get page messages: |
204ms |
get tp. blocked users: |
1ms |
others: | 308ms |
total: | 612ms |
0 / 0 |