This commit is contained in:
PastSaid
2024-03-28 11:30:14 +08:00
parent c31957eb64
commit 912bea60ac
64 changed files with 5868 additions and 158 deletions

View File

@@ -0,0 +1,43 @@
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="4.0">
<PropertyGroup>
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
<SchemaVersion>2.0</SchemaVersion>
<ProjectGuid>62bc7efa-7e95-4593-a146-8a6ac44278fb</ProjectGuid>
<ProjectHome>.</ProjectHome>
<StartupFile>
</StartupFile>
<SearchPath>
</SearchPath>
<WorkingDirectory>.</WorkingDirectory>
<OutputPath>.</OutputPath>
<Name>CYG.Python</Name>
<RootNamespace>CYG.Python</RootNamespace>
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)' == 'Debug' ">
<DebugSymbols>true</DebugSymbols>
<EnableUnmanagedDebugging>false</EnableUnmanagedDebugging>
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)' == 'Release' ">
<DebugSymbols>true</DebugSymbols>
<EnableUnmanagedDebugging>false</EnableUnmanagedDebugging>
</PropertyGroup>
<ItemGroup>
<Compile Include="SAL_SaleOrder\OperationEventPlugInEx.py" />
</ItemGroup>
<ItemGroup>
<Folder Include="SAL_SaleOrder\" />
<Folder Include="SAL_SaleOrder\sql\" />
</ItemGroup>
<ItemGroup>
<Content Include="SAL_SaleOrder\sql\销售订单保存时更新关联订单信息.sql" />
</ItemGroup>
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)\Python Tools\Microsoft.PythonTools.targets" />
<!-- Uncomment the CoreCompile target to enable the Build command in
Visual Studio and specify your pre- and post-build commands in
the BeforeBuild and AfterBuild targets below. -->
<!--<Target Name="CoreCompile" />-->
<Target Name="BeforeBuild">
</Target>
<Target Name="AfterBuild">
</Target>
</Project>

View File

@@ -0,0 +1,92 @@
#<23><><EFBFBD><EFBFBD>clr<6C><72><EFBFBD>п<EFBFBD>
import clr
#<23><><EFBFBD>Ӷ<EFBFBD>cloud<75><64><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ij<EFBFBD><C4B3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
clr.AddReference('System')
clr.AddReference('System.Data')
clr.AddReference('Kingdee.BOS')
clr.AddReference('Kingdee.BOS.Core')
clr.AddReference('Kingdee.BOS.App')
clr.AddReference('Kingdee.BOS.Contracts')
clr.AddReference('Kingdee.BOS.DataEntity')
clr.AddReference('Kingdee.BOS.ServiceHelper')
#dairycloud<75><64><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>еij<D0B5><C4B3><EFBFBD>ʵ<EFBFBD><CAB5><EFBFBD><EFBFBD><EFBFBD>󣨷<EFBFBD><F3A3A8B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ռ<D5BC><EFBFBD><EBA3AC><EFBFBD><EFBFBD><EFBFBD>ݹ鵼<DDB9>
from Kingdee.BOS.Core import *
from Kingdee.BOS.Util import *
from Kingdee.BOS.Core.Bill import *
from Kingdee.BOS.Core.Bill.PlugIn import *
from Kingdee.BOS.Orm.DataEntity import *
from Kingdee.BOS.Core.DynamicForm.PlugIn import *
from Kingdee.BOS.Core.DynamicForm.PlugIn.Args import *
from Kingdee.BOS.Core.DynamicForm.PlugIn.ControlModel import *
from System import *
from System.Data import *
from Kingdee.BOS.App.Data import *
from System.Collections.Generic import List
from Kingdee.BOS.ServiceHelper import *
def EndOperationTransaction(e):
# <20><><EFBFBD><EFBFBD>8<EFBFBD>ύ9<E1BDBB><39><EFBFBD><EFBFBD>1<EFBFBD><31><EFBFBD><EFBFBD><EFBFBD><EFBFBD>26ɾ<36><C9BE>3
if this.FormOperation.OperationId == 8:
for data in e.DataEntitys:
documentStatus = data["DocumentStatus"]
if documentStatus == "C":
# entry = data["SaleOrderEntry"]
billId = data["Id"]
# formId = data["FFormId"]
sqlLList = List[str]();
# <20><><EFBFBD><EFBFBD>֪ͨ<CDA8><D6AA>
sqlLList.Add("""/*dialect*/
UPDATE tt SET tt.F_CYG_TEXT1 = STUFF((SELECT distinct ','+ t0e.F_CYG_TEXT4
FROM T_SAL_ORDERENTRY t0e --<2D><><EFBFBD>۶<EFBFBD><DBB6><EFBFBD>
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk --<2D><><EFBFBD><EFBFBD>֪ͨ<CDA8><D6AA><EFBFBD><EFBFBD>ϵ<EFBFBD><CFB5>
ON t0e.FID = t1e_lk.FSBILLID AND t0e.FENTRYID = t1e_lk.FSID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
WHERE t1e_lk.FENTRYID = tt.FENTRYID --ƴ<>ӹ<EFBFBD><D3B9><EFBFBD><EFBFBD>ֶ<EFBFBD>
FOR XML PATH('')
),1,1,'') --stuff <20><>ת<EFBFBD>к<EFBFBD>ƴ<EFBFBD><C6B4>
FROM T_SAL_DELIVERYNOTICEENTRY tt
WHERE EXISTS (SELECT 1 FROM T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk WHERE t1e_lk.FSBILLID = {0} AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY' AND t1e_lk.FENTRYID = tt.FENTRYID)
""".format(billId))
# <20><><EFBFBD>۳<EFBFBD><DBB3>
sqlLList.Add("""
UPDATE tt SET tt.F_CYG_TEXT1 = STUFF((SELECT distinct ','+ t0e.F_CYG_TEXT4
FROM T_SAL_ORDERENTRY t0e --<2D><><EFBFBD>۶<EFBFBD><DBB6><EFBFBD>
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk --<2D><><EFBFBD><EFBFBD>֪ͨ<CDA8><D6AA><EFBFBD><EFBFBD>ϵ<EFBFBD><CFB5>
ON t0e.FID = t1e_lk.FSBILLID AND t0e.FENTRYID = t1e_lk.FSID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
INNER JOIN T_SAL_DELIVERYNOTICEENTRY t1e ON t1e.FENTRYID = t1e_lk.FENTRYID --<2D><><EFBFBD><EFBFBD>֪ͨ<CDA8><D6AA>
INNER JOIN T_SAL_OUTSTOCKENTRY_LK t2e_lk --<2D><><EFBFBD>۳<EFBFBD><DBB3><EFBFBD><E2B5A5>ϵ<EFBFBD><CFB5>
ON t1e.FID = t2e_lk.FSBILLID AND t1e.FENTRYID = t2e_lk.FSID AND t2e_lk.FSTABLENAME = 'T_SAL_DELIVERYNOTICEENTRY'
WHERE t2e_lk.FENTRYID = tt.FENTRYID --ƴ<>ӹ<EFBFBD><D3B9><EFBFBD><EFBFBD>ֶ<EFBFBD>
FOR XML PATH('')
),1,1,'') --stuff <20><>ת<EFBFBD>к<EFBFBD>ƴ<EFBFBD><C6B4>
FROM T_SAL_OUTSTOCKENTRY tt
WHERE EXISTS (
SELECT 1 FROM T_SAL_OUTSTOCKENTRY_LK t2e_lk
INNER JOIN T_SAL_DELIVERYNOTICEENTRY t1e on t2e_lk.FSBILLID = t1e.FID AND t2e_lk.FSID = t1e.FENTRYID
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk on t1e_lk.FENTRYID = t1e.FENTRYID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
WHERE t2e_lk.FENTRYID = tt.FENTRYID AND t2e_lk.FSTABLENAME = 'T_SAL_DELIVERYNOTICEENTRY' AND t1e_lk.FSBILLID = {0})
""".format(billId))
# Ӧ<>յ<EFBFBD>
sqlLList.Add("""
UPDATE tt SET tt.F_CYG_TEXT1 = STUFF((SELECT distinct ','+ t0e.F_CYG_TEXT4
FROM T_SAL_ORDERENTRY t0e --<2D><><EFBFBD>۶<EFBFBD><DBB6><EFBFBD>
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk --<2D><><EFBFBD><EFBFBD>֪ͨ<CDA8><D6AA><EFBFBD><EFBFBD>ϵ<EFBFBD><CFB5>
ON t0e.FID = t1e_lk.FSBILLID AND t0e.FENTRYID = t1e_lk.FSID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
INNER JOIN T_SAL_DELIVERYNOTICEENTRY t1e ON t1e.FENTRYID = t1e_lk.FENTRYID --<2D><><EFBFBD><EFBFBD>֪ͨ<CDA8><D6AA>
INNER JOIN T_SAL_OUTSTOCKENTRY_LK t2e_lk --<2D><><EFBFBD>۳<EFBFBD><DBB3><EFBFBD><E2B5A5>ϵ<EFBFBD><CFB5>
ON t1e.FID = t2e_lk.FSBILLID AND t1e.FENTRYID = t2e_lk.FSID AND t2e_lk.FSTABLENAME = 'T_SAL_DELIVERYNOTICEENTRY'
INNER JOIN T_SAL_OUTSTOCKENTRY t2e on t2e.FENTRYID = t2e_lk.FENTRYID
INNER JOIN T_AR_RECEIVABLEENTRY_LK t3e_lk
on t2e.FID = t3e_lk.FSBILLID AND t2e.FENTRYID = t3e_lk.FSID AND t3e_lk.FSTABLENAME = 'T_SAL_OUTSTOCKENTRY'
WHERE t3e_lk.FENTRYID = tt.FENTRYID --ƴ<>ӹ<EFBFBD><D3B9><EFBFBD><EFBFBD>ֶ<EFBFBD>
FOR XML PATH('')
),1,1,'') --stuff <20><>ת<EFBFBD>к<EFBFBD>ƴ<EFBFBD><C6B4>
FROM T_AR_RECEIVABLEENTRY tt
WHERE EXISTS (
SELECT 1 FROM T_AR_RECEIVABLEENTRY_LK t3e_lk
INNER JOIN T_SAL_OUTSTOCKENTRY t2e on t2e.FID = t3e_lk.FSBILLID AND t2e.FENTRYID = t3e_lk.FSID
INNER JOIN T_SAL_OUTSTOCKENTRY_LK t2e_lk on t2e.FENTRYID = t2e_lk.FENTRYID AND t2e_lk.FSTABLENAME = 'T_SAL_DELIVERYNOTICEENTRY'
INNER JOIN T_SAL_DELIVERYNOTICEENTRY t1e on t2e_lk.FSBILLID = t1e.FID AND t2e_lk.FSID = t1e.FENTRYID
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk on t1e_lk.FENTRYID = t1e.FENTRYID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
WHERE t3e_lk.FENTRYID = tt.FENTRYID AND t3e_lk.FSTABLENAME = 'T_SAL_OUTSTOCKENTRY' AND t1e_lk.FSBILLID = {0})
""".format(billId))
DBUtils.ExecuteBatch(this.Context,sqlLList,sqlLList.Count);

View File

@@ -0,0 +1,81 @@
--/***********<EFBFBD><EFBFBD><EFBFBD><EFBFBD>֪ͨ<EFBFBD><EFBFBD>start*********************/
--UPDATE tt SET tt.F_CYG_TEXT1 =
SELECT tt.FENTRYID
,STUFF((SELECT distinct ','+ t0e.F_CYG_TEXT4
FROM T_SAL_ORDERENTRY t0e --<EFBFBD><EFBFBD><EFBFBD>۶<EFBFBD><EFBFBD><EFBFBD>
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk --<EFBFBD><EFBFBD><EFBFBD><EFBFBD>֪ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵ<EFBFBD><EFBFBD>
ON t0e.FID = t1e_lk.FSBILLID AND t0e.FENTRYID = t1e_lk.FSID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
WHERE t1e_lk.FENTRYID = tt.FENTRYID --ƴ<EFBFBD>ӹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֶ<EFBFBD>
FOR XML PATH('')
),1,1,'') --stuff <EFBFBD><EFBFBD>ת<EFBFBD>к<EFBFBD>ƴ<EFBFBD><EFBFBD>
FROM T_SAL_DELIVERYNOTICEENTRY tt
WHERE EXISTS (SELECT 1 FROM T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk WHERE t1e_lk.FSBILLID = 100040 AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY' AND t1e_lk.FENTRYID = tt.FENTRYID)
--/***********<EFBFBD><EFBFBD><EFBFBD><EFBFBD>֪ͨ<EFBFBD><EFBFBD>end*********************/
--/***********<EFBFBD><EFBFBD><EFBFBD>۳<EFBFBD><EFBFBD>ⵥstart*********************/
--UPDATE tt SET tt.F_CYG_TEXT1 =
SELECT tt.FENTRYID
,STUFF((SELECT distinct ','+ t0e.F_CYG_TEXT4
FROM T_SAL_ORDERENTRY t0e --<EFBFBD><EFBFBD><EFBFBD>۶<EFBFBD><EFBFBD><EFBFBD>
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk --<EFBFBD><EFBFBD><EFBFBD><EFBFBD>֪ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵ<EFBFBD><EFBFBD>
ON t0e.FID = t1e_lk.FSBILLID AND t0e.FENTRYID = t1e_lk.FSID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
INNER JOIN T_SAL_DELIVERYNOTICEENTRY t1e ON t1e.FENTRYID = t1e_lk.FENTRYID --<EFBFBD><EFBFBD><EFBFBD><EFBFBD>֪ͨ<EFBFBD><EFBFBD>
INNER JOIN T_SAL_OUTSTOCKENTRY_LK t2e_lk --<EFBFBD><EFBFBD><EFBFBD>۳<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵ<EFBFBD><EFBFBD>
ON t1e.FID = t2e_lk.FSBILLID AND t1e.FENTRYID = t2e_lk.FSID AND t2e_lk.FSTABLENAME = 'T_SAL_DELIVERYNOTICEENTRY'
WHERE t2e_lk.FENTRYID = tt.FENTRYID --ƴ<EFBFBD>ӹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֶ<EFBFBD>
FOR XML PATH('')
),1,1,'') --stuff <EFBFBD><EFBFBD>ת<EFBFBD>к<EFBFBD>ƴ<EFBFBD><EFBFBD>
FROM T_SAL_OUTSTOCKENTRY tt
WHERE EXISTS (
SELECT 1 FROM T_SAL_OUTSTOCKENTRY_LK t2e_lk
INNER JOIN T_SAL_DELIVERYNOTICEENTRY t1e on t2e_lk.FSBILLID = t1e.FID AND t2e_lk.FSID = t1e.FENTRYID
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk on t1e_lk.FENTRYID = t1e.FENTRYID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
WHERE t2e_lk.FENTRYID = tt.FENTRYID AND t2e_lk.FSTABLENAME = 'T_SAL_DELIVERYNOTICEENTRY' AND t1e_lk.FSBILLID = 100040)
--/***********<EFBFBD><EFBFBD><EFBFBD>۳<EFBFBD><EFBFBD>ⵥend*********************/
--/***********Ӧ<EFBFBD>յ<EFBFBD>start*********************/
--UPDATE tt SET tt.F_CYG_TEXT1 =
SELECT tt.FENTRYID
,STUFF((SELECT distinct ','+ t0e.F_CYG_TEXT4
FROM T_SAL_ORDERENTRY t0e --<EFBFBD><EFBFBD><EFBFBD>۶<EFBFBD><EFBFBD><EFBFBD>
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk --<EFBFBD><EFBFBD><EFBFBD><EFBFBD>֪ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵ<EFBFBD><EFBFBD>
ON t0e.FID = t1e_lk.FSBILLID AND t0e.FENTRYID = t1e_lk.FSID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
INNER JOIN T_SAL_DELIVERYNOTICEENTRY t1e ON t1e.FENTRYID = t1e_lk.FENTRYID --<EFBFBD><EFBFBD><EFBFBD><EFBFBD>֪ͨ<EFBFBD><EFBFBD>
INNER JOIN T_SAL_OUTSTOCKENTRY_LK t2e_lk --<EFBFBD><EFBFBD><EFBFBD>۳<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵ<EFBFBD><EFBFBD>
ON t1e.FID = t2e_lk.FSBILLID AND t1e.FENTRYID = t2e_lk.FSID AND t2e_lk.FSTABLENAME = 'T_SAL_DELIVERYNOTICEENTRY'
INNER JOIN T_SAL_OUTSTOCKENTRY t2e on t2e.FENTRYID = t2e_lk.FENTRYID
INNER JOIN T_AR_RECEIVABLEENTRY_LK t3e_lk
on t2e.FID = t3e_lk.FSBILLID AND t2e.FENTRYID = t3e_lk.FSID AND t3e_lk.FSTABLENAME = 'T_SAL_OUTSTOCKENTRY'
WHERE t3e_lk.FENTRYID = tt.FENTRYID --ƴ<EFBFBD>ӹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֶ<EFBFBD>
FOR XML PATH('')
),1,1,'') --stuff <EFBFBD><EFBFBD>ת<EFBFBD>к<EFBFBD>ƴ<EFBFBD><EFBFBD>
FROM T_AR_RECEIVABLEENTRY tt
WHERE EXISTS (
SELECT 1 FROM T_AR_RECEIVABLEENTRY_LK t3e_lk
INNER JOIN T_SAL_OUTSTOCKENTRY t2e on t2e.FID = t3e_lk.FSBILLID AND t2e.FENTRYID = t3e_lk.FSID
INNER JOIN T_SAL_OUTSTOCKENTRY_LK t2e_lk on t2e.FENTRYID = t2e_lk.FENTRYID AND t2e_lk.FSTABLENAME = 'T_SAL_DELIVERYNOTICEENTRY'
INNER JOIN T_SAL_DELIVERYNOTICEENTRY t1e on t2e_lk.FSBILLID = t1e.FID AND t2e_lk.FSID = t1e.FENTRYID
INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk on t1e_lk.FENTRYID = t1e.FENTRYID AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
WHERE t3e_lk.FENTRYID = tt.FENTRYID AND t3e_lk.FSTABLENAME = 'T_SAL_OUTSTOCKENTRY' AND t1e_lk.FSBILLID = 100040)
--/***********Ӧ<EFBFBD>յ<EFBFBD>end*********************/
--SELECT
-- t0e.FID
-- ,t0e.FENTRYID
-- ,t1e.FENTRYID AS '<27><><EFBFBD><EFBFBD>֪ͨ<CDA8><D6AA>ʵ<EFBFBD><CAB5>id'
-- ,ISNULL(t2e.FENTRYID, 0) AS '<27><><EFBFBD>۳<EFBFBD><DBB3>ⵥʵ<E2B5A5><CAB5>id'
-- ,ISNULL(t3e.FENTRYID, 0) AS 'Ӧ<>յ<EFBFBD>ʵ<EFBFBD><CAB5>id'
--FROM T_SAL_ORDERENTRY t0e
-- INNER JOIN T_SAL_DELIVERYNOTICEENTRY_LK t1e_lk on t0e.FID = t1e_lk.FSBILLID AND t0e.FENTRYID = t1e_lk.FSID
-- AND t1e_lk.FSTABLENAME = 'T_SAL_ORDERENTRY'
-- INNER JOIN T_SAL_DELIVERYNOTICEENTRY t1e on t1e.FENTRYID = t1e_lk.FENTRYID
-- INNER JOIN T_SAL_OUTSTOCKENTRY_LK t2e_lk on t1e.FID = t2e_lk.FSBILLID AND t1e.FENTRYID = t2e_lk.FSID
-- AND t2e_lk.FSTABLENAME = 'T_SAL_DELIVERYNOTICEENTRY'
-- INNER JOIN T_SAL_OUTSTOCKENTRY t2e on t2e.FENTRYID = t2e_lk.FENTRYID
-- INNER JOIN T_AR_RECEIVABLEENTRY_LK t3e_lk on t2e.FID = t3e_lk.FSBILLID AND t2e.FENTRYID = t3e_lk.FSID
-- AND t3e_lk.FSTABLENAME = 'T_SAL_OUTSTOCKENTRY'
-- INNER JOIN T_AR_RECEIVABLEENTRY t3e on t3e.FENTRYID = t3e_lk.FENTRYID
--WHERE
-- t0e.FID = 100007