Код: Выделить всё
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 ')'.
Есть идеи, что здесь происходит?
п>
Подробнее здесь: https://stackoverflow.com/questions/793 ... on-in-odbc
Мобильная версия