Блокировка таблицы с транзакцией в ODBCC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Блокировка таблицы с транзакцией в ODBC

Сообщение Anonymous »

Код: Выделить всё

ret = SQLExecDirect( stmt2, "BEGIN", SQL_NTS );
ret = SQLTables( stmt1 );
for( SQLFetch( stmt1 ); ; SQLFetch( stmt1 ) )
{
// get catalog
// get schema
// get table
ret = SQLExecDirect( stmt2, "IF NOT EXIST( SELECT * FROM  WHERE name =  AND schema =  ) INSERT INTO  VALUES( , , .... )", SQL_NTS );
}
ret = SQLExecDirect( stmt2, "COMMIT", SQL_NTS );
(проверка ошибок и подготовка опущены для ясности)
У меня есть пара вопросов относительно приведенного выше кода.
  • На период этой транзакции мне нужно, чтобы была заблокирована, чтобы невозможно было выполнить чтение/запись.
    Как я могу это сделать?
  • Думаю, мне нужна одна транзакция. Правильно ли я делаю это с помощью запроса оператора INSERT?
  • Должен ли я сделать 2 запроса в транзакции, разделив проверку записи и фактическую вставку?
РЕДАКТИРОВАТЬ:
Это то, чего я пытаюсь достичь (переведено вашему синтаксису):

Код: Выделить всё

INSERT INTO my_table SELECT( 0, 'abcatcol', (SELECT object_id FROM
sys.objects o, sys.schemas s WHERE s.schema_id = o.schema_id AND o.name =
'abcatcol' AND s.name = 'dbo')
WHERE NOT EXISTS(SELECT * FROM my_table WHERE abt_tnam='abcatcol' AND abt_ownr='dbo') );
Однако я получаю следующие ошибки:

Код: Выделить всё

Msg 102, Level 15, State 1, Line 2
Incorrect syntax near ','.
Msg 156, Level 15, State 1, Line 3
Incorrect syntax near the keyword 'WHERE'.
Msg 102, Level 15, State 1, Line 3
Incorrect syntax near ')'.
Я думаю, что только первый из них имеет значение — это SELECT( 0,.
Есть идеи, что здесь происходит?
п>

Подробнее здесь: https://stackoverflow.com/questions/793 ... on-in-odbc
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»