Django вызывает хранимую процедуру, транзакция не фиксируется или не выполняется - PullRequest
0 голосов
/ 14 июня 2019

У меня есть этот код, который выполняется на основе команды управления django.Помогает загрузка группы данных с использованием временных таблиц и библиотеки панд

def MergeAce(table=None,user=1,db_instance=None):
    if db_instance:
        db = db_instance
    else:
        return False

    with connections[db].cursor() as cursor:
        result = cursor.execute(f"spMergeAce {user} , '{table}'")
        cursor.commit()
    return result

Я знаю, что неправильно вызываю параметры, и в настоящее время callproc не работает с pyobdc .

Однако, похоже, что часть кода выполняется, а часть - нет.Это образец процедуры ее вызова.Обратите внимание на это с помощью оператора слияния.

-- =============================================
-- Author:      <Pickle,Travis>
-- Create date: <June 13 2019>
-- Description: <Create and update ace from temp table>
-- =============================================
ALTER PROCEDURE [dbo].[spMergeAce]
    -- Add the parameters for the stored procedure here
    @user int = 1,
    @table varchar(50)

AS
BEGIN
    SET NOCOUNT ON;

    declare @query nvarchar(max) = ''
    -- ,@user int = 1, @table varchar(50) = 'cat'



    set @query = N'
          with cte as(
        SELECT aclid, hash, ConfigLine,  RN = ROW_NUMBER()
         OVER(PARTITION BY aclid, hash, ConfigLine ORDER BY aclid, hash, ConfigLine)
           FROM [dbo].['+ @table + '] new) delete from cte where RN > 1;


    MERGE [dbo].[ACE] AS TARGET
    USING [dbo].['+ @table + '] AS SOURCE 
    ON (TARGET.aclid = SOURCE.aclid and TARGET.hash = SOURCE.hash and TARGET.configline = SOURCE.configline ) 
    WHEN MATCHED
        AND (TARGET.[hitcount] <> SOURCE.[hitcount]
        OR TARGET.[line] <> SOURCE.[Line]
        OR TARGET.[line] is NULL
        OR TARGET.[hitcount] is NULL
        )
        THEN UPDATE SET
            TARGET.[hitcount] = SOURCE.[hitcount],
            TARGET.[UpdateDate] = getdate(),
            TARGET.[Source] = SOURCE.[Source] ,
            TARGET.[Service] = SOURCE.[Service],
            TARGET.[Protocol] = SOURCE.[Protocol],
            TARGET.[Destination] = SOURCE.[Destination],
            TARGET.[line] = SOURCE.[Line] ,
            TARGET.[Inactive] = 0,
            TARGET.[InactiveDate] = NULL
    WHEN NOT MATCHED BY TARGET 
        THEN
            INSERT (
                [ACLid],
                [Hash],
                [Source],
                [Destination],
                [Service],
                [Protocol],
                [ConfigLine],
                [CreateDate],
                [UpdateDate],
                [CreateUser],
                [UpdateUser],
                [line],
                [hitcount],
                [Inactive])
            VALUES (
                SOURCE.[aclid],
                SOURCE.[hash],
                SOURCE.[Source],
                SOURCE.[Destination],
                SOURCE.[Service],
                SOURCE.[Protocol],
                SOURCE.[ConfigLine],
                getdate(),
                getdate(),
                ' + cast(@user as varchar(50)) + ' ,
                  ' + cast(@user as varchar(50)) + ',
                SOURCE.[Line],
                SOURCE.[hitcount],
                0)          

    OUTPUT $action, 
    INSERTED.[aclid] AS SourceAclId, 
    INSERTED.[ConfigLine] AS SourceConfigLine, 
    INSERTED.[Hash] AS SourceHash, 
    INSERTED.[Protocol] AS SourceProtocol,
    INSERTED.[Service] AS SourceService,
    INSERTED.[Source] AS SourceSourceNets,
    INSERTED.[Destination] AS SourceDestinationNets,
    INSERTED.[Inactive] as SourceInactive; 


    UPDATE TARGET
    set
        TARGET.updateuser = ' + cast(@user as varchar(50)) + ',
        TARGET.updatedate = getdate(),
        TARGET.[Inactive] = 1,
        TARGET.[InactiveDate] = getdate()
    from [dbo].[ACE] AS TARGET
    left join [dbo].['+ @table + '] AS SOURCE on TARGET.aclid = SOURCE.aclid and TARGET.hash = SOURCE.hash and TARGET.configline = SOURCE.configline
    where SOURCE.id is null AND TARGET.[Inactive] <> 1 AND TARGET.aclid in (
        SELECT distinct ace2.aclid from ace ace2 join acl on acl.id = ace2.aclid where acl.zoneid in (SELECT distinct zoneid from [dbo].['+ @table + '])); 

    drop table [dbo].['+ @table + '];
    '


    exec sp_executesql @query
    COMMIT
END

Более того, если я обновлю переменные в хранимой процедуре, она будет работать в SSMS.Не уверен, является ли django / pyobdc причиной для вызова хранимой процедуры или это моя хранимая процедура.

1 Ответ

0 голосов
/ 02 июля 2019

Так что мне не хватало нескольких вещей. Но это то, что решило это. EXEC был добавлен


def MergeAcl(table=None,user=1,db_instance=None):
    if db_instance:
        db = db_instance
    else:
        return False
    with connections[db].cursor() as cursor:
        try:
            cursor.execute(f"EXEC [dbo].spMergeAcl @user = {user}, @table = [{table}]")
        except Exception as e:
            logger.error(e)
            return False
        rows = cursor.fetchall()
        while rows:
            logger.debug(rows) # not needed, just used for debugging
            if cursor.nextset():
                rows = cursor.fetchall()
            else:
                rows = None
    return True
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...