Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
SQLEndTran и SQLSetConnectAttr
|
|||
|---|---|---|---|
|
#18+
Здравствуйте, пытаюсь использовать транзакции: 1. Вызываю SQLSetConnectAttr(hdbc1,SQL_AUTOCOMMIT,SQL_AUTOCOMMIT_OFF,SQL_NTS); 2. Вызываю несколько своих запросов.... 3. Вызываю SQLEndTran(SQL_HANDLE_DBC, hdbc1, SQL_COMMIT); 4. Вызываю SQLSetConnectAttr(hdbc1,SQL_AUTOCOMMIT,SQL_AUTOCOMMIT_ON,SQL_NTS); Проблема заключается в том, четвертый пункт нормально не отрабатывает. В профайлере я не вижу "set implicit_transactions off". Все это производит в пределах одной функции. При вызове другой функции где вначале вызываю SQLSetConnectAttr(hdbc1,SQL_AUTOCOMMIT,SQL_AUTOCOMMIT_ON,SQL_NTS) в профайлере проходит "set implicit_transactions off". Вызов SQLSetConnectAttr последовательно несколько раз не помогает. при этом если убрать SQLEndTran и оставить только SQLSetConnectAttr, то запросы отрабатывают, т.е. все-таки эта функция что-то делает. Возможно это проявление того, что в пределах пунктов 1-4 я несколько раз вызываю пары: SQLAllocHandle(SQL_HANDLE_STMT,hdbc1,&hstmt1); SQLFreeHandle(SQL_HANDLE_STMT,hstmt1); В чем может быть причина? Такое ощущение, что то-то висит в памяти, что мешает нормально отработать SQLSetConnectAttr... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.11.2013, 14:16 |
|
||
|
SQLEndTran и SQLSetConnectAttr
|
|||
|---|---|---|---|
|
#18+
max950В чем может быть причина? В том, что установка атрибута и не обязана делать что-то видимое снаружи. В твоём случае транзакция уже закоммичена, а новая ещё не стартовала. Драйверу, который об этом знает, достаточно установить какой-нибудь внутренний флаг. Попробуй посмотреть что будет при последующем вызове чего-то, что должно стартовать новую транзакцию. Posted via ActualForum NNTP Server 1.5 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.11.2013, 14:46 |
|
||
|
SQLEndTran и SQLSetConnectAttr
|
|||
|---|---|---|---|
|
#18+
Также нужно убедиться, что после SQLEndTran(SQL_HANDLE_DBC, hdbc1, SQL_COMMIT); коннекция не содержит активную транзакцию. Т.е. что по COMMIT транзакция была закоммичена реально. Как я понял, это у тебя MS SQLServer, так что в этом поможет @@trancount, или как его там сейчас называют. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.11.2013, 15:11 |
|
||
|
SQLEndTran и SQLSetConnectAttr
|
|||
|---|---|---|---|
|
#18+
-------------------- В том, что установка атрибута и не обязана делать что-то видимое снаружи. В твоём случае транзакция уже закоммичена, а новая ещё не стартовала. Драйверу, который об этом знает, достаточно установить какой-нибудь внутренний флаг. Попробуй посмотреть что будет при последующем вызове чего-то, что должно стартовать новую транзакцию. -------------------- Да, похоже на то, добавил один "лишний" запрос после SQLSetConnectAttr и увидел "set implicit_transactions off" -------------------- Также нужно убедиться, что после SQLEndTran(SQL_HANDLE_DBC, hdbc1, SQL_COMMIT); коннекция не содержит активную транзакцию. Т.е. что по COMMIT транзакция была закоммичена реально. Как я понял, это у тебя MS SQLServer, так что в этом поможет @@trancount, или как его там сейчас называют. -------------------- В профайлере после вызова SQLEndTran я вижу "IF @@TRANCOUNT > 0 COMMIT TRAN" кроме того вижу, что прошли изменения в базу. Больше спасибо за помощь. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.11.2013, 15:18 |
|
||
|
|

start [/forum/topic.php?fid=57&msg=38468683&tid=2019860]: |
0ms |
get settings: |
10ms |
get forum list: |
14ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
161ms |
get topic data: |
9ms |
get forum data: |
2ms |
get page messages: |
36ms |
get tp. blocked users: |
1ms |
| others: | 14ms |
| total: | 253ms |

| 0 / 0 |
