У меня есть этот код, который выполняется на основе команды управления 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 причиной для вызова хранимой процедуры или это моя хранимая процедура.