USP_DATAFORMTEMPLATE_EDITLOAD_MKTSEGMENTATIONTESTSEGMENT_2
The load procedure used by the edit dataform template "Marketing Effort Test Segment Edit Form 2"
Parameters
| Parameter | Parameter Type | Mode | Description |
|---|---|---|---|
| @ID | uniqueidentifier | IN | The input ID parameter used to load the fields defined on the form. |
| @DATALOADED | bit | INOUT | Output parameter indicating whether or not data was actually loaded. |
| @SEGMENTID | uniqueidentifier | INOUT | Segment |
| @SEGMENTATIONID | uniqueidentifier | INOUT | Segmentation |
| @SEGMENTATIONACTIVE | bit | INOUT | Marketing effort active? |
| @NAME | nvarchar(100) | INOUT | Name |
| @DESCRIPTION | nvarchar(255) | INOUT | Description |
| @CODE | nvarchar(10) | INOUT | Code |
| @PACKAGEID | uniqueidentifier | INOUT | Package |
| @PACKAGECODE | nvarchar(10) | INOUT | Package code |
| @RESPONSERATE | decimal(5, 2) | INOUT | Response rate |
| @GIFTAMOUNT | money | INOUT | Gift amount |
| @SAMPLESIZE | int | INOUT | Sample size |
| @SAMPLESIZETYPECODE | tinyint | INOUT | Sample size type |
| @SAMPLESIZEMETHODCODE | tinyint | INOUT | Sample size method |
| @SOURCECODEID | uniqueidentifier | INOUT | Source code ID |
| @ASKLADDERID | uniqueidentifier | INOUT | Ask ladder |
| @RECORDSOURCEID | uniqueidentifier | INOUT | Ask ladder record source ID |
| @TSLONG | bigint | INOUT | Output parameter indicating the TSLONG value of the record being edited. This is used to manage multi-user concurrency issues when multiple users access the same record. |
| @SEGMENTTYPECODE | tinyint | INOUT | Segment type code |
| @SEGMENTATIONSITEID | uniqueidentifier | INOUT | Marketing effort site ID |
| @MAILINGTYPECODE | tinyint | INOUT | Marketing effort type code |
| @ISVENDORMANAGED | bit | INOUT | Vendor managed |
Definition
Copy
CREATE procedure dbo.[USP_DATAFORMTEMPLATE_EDITLOAD_MKTSEGMENTATIONTESTSEGMENT_2]
(
@ID uniqueidentifier,
@DATALOADED bit = 0 output,
@SEGMENTID uniqueidentifier = null output,
@SEGMENTATIONID uniqueidentifier = null output,
@SEGMENTATIONACTIVE bit = null output,
@NAME nvarchar(100) = null output,
@DESCRIPTION nvarchar(255) = null output,
@CODE nvarchar(10) = null output,
@PACKAGEID uniqueidentifier = null output,
@PACKAGECODE nvarchar(10) = null output,
@RESPONSERATE decimal(5,2) = null output,
@GIFTAMOUNT money = null output,
@SAMPLESIZE int = null output,
@SAMPLESIZETYPECODE tinyint = null output,
@SAMPLESIZEMETHODCODE tinyint = null output,
@SOURCECODEID uniqueidentifier = null output,
@ASKLADDERID uniqueidentifier = null output,
@RECORDSOURCEID uniqueidentifier = null output,
@TSLONG bigint = 0 output,
@SEGMENTTYPECODE tinyint = null output,
@SEGMENTATIONSITEID uniqueidentifier = null output,
@MAILINGTYPECODE tinyint = null output,
@ISVENDORMANAGED bit = null output
)
as
set nocount on;
set @DATALOADED = 0;
set @TSLONG = 0;
/* Load the test segment */
select
@DATALOADED = 1,
@SEGMENTID = [MKTSEGMENTATIONTESTSEGMENT].[SEGMENTID],
@SEGMENTATIONID = [MKTSEGMENTATION].[ID],
@SEGMENTATIONACTIVE = [MKTSEGMENTATION].[ACTIVE],
@NAME = [MKTSEGMENTATIONTESTSEGMENT].[NAME],
@DESCRIPTION = [MKTSEGMENTATIONTESTSEGMENT].[DESCRIPTION],
@CODE = [MKTSEGMENTATIONTESTSEGMENT].[CODE],
@PACKAGEID = [MKTSEGMENTATIONTESTSEGMENT].[PACKAGEID],
@PACKAGECODE = (case when [MKTSEGMENTATION].[ACTIVE] = 1 then [MKTSEGMENTATIONPACKAGE].[CODE] else [MKTPACKAGE].[CODE] end),
@RESPONSERATE = [MKTSEGMENTATIONTESTSEGMENT].[RESPONSERATE],
@GIFTAMOUNT = [MKTSEGMENTATIONTESTSEGMENT].[GIFTAMOUNT],
@SAMPLESIZE = [MKTSEGMENTATIONTESTSEGMENT].[SAMPLESIZE],
@SAMPLESIZETYPECODE = [MKTSEGMENTATIONTESTSEGMENT].[SAMPLESIZETYPECODE],
@SAMPLESIZEMETHODCODE = [MKTSEGMENTATIONTESTSEGMENT].[SAMPLESIZEMETHODCODE],
@SOURCECODEID = [MKTSEGMENTATION].[SOURCECODEID],
@ASKLADDERID = [MKTSEGMENTATIONTESTSEGMENT].[ASKLADDERID],
@RECORDSOURCEID = (select [QUERYVIEWCATALOGID] from dbo.[MKTSEGMENT] where [ID]=[MKTSEGMENTATIONSEGMENT].[SEGMENTID]),
@TSLONG = [MKTSEGMENTATIONTESTSEGMENT].[TSLONG],
@SEGMENTTYPECODE = [MKTSEGMENT].[SEGMENTTYPECODE],
@SEGMENTATIONSITEID = [MKTSEGMENTATION].[SITEID],
@MAILINGTYPECODE = [MKTSEGMENTATION].[MAILINGTYPECODE],
@ISVENDORMANAGED = dbo.[UFN_MKTSEGMENT_ISVENDORMANAGEDLIST]([MKTSEGMENT].[ID])
from dbo.[MKTSEGMENTATIONTESTSEGMENT]
inner join dbo.[MKTSEGMENTATIONSEGMENT] on [MKTSEGMENTATIONSEGMENT].[ID] = [MKTSEGMENTATIONTESTSEGMENT].[SEGMENTID]
inner join dbo.[MKTSEGMENT] on [MKTSEGMENTATIONSEGMENT].[SEGMENTID] = [MKTSEGMENT].[ID]
inner join dbo.[MKTSEGMENTATION] on [MKTSEGMENTATION].[ID] = [MKTSEGMENTATIONSEGMENT].[SEGMENTATIONID]
inner join dbo.[MKTPACKAGE] on [MKTPACKAGE].[ID] = [MKTSEGMENTATIONTESTSEGMENT].[PACKAGEID]
left join dbo.[MKTSEGMENTATIONPACKAGE] on [MKTSEGMENTATIONPACKAGE].[SEGMENTATIONID] = [MKTSEGMENTATION].[ID] and [MKTSEGMENTATIONPACKAGE].[PACKAGEID] = [MKTPACKAGE].[ID]
where [MKTSEGMENTATIONTESTSEGMENT].[ID] = @ID;
if @DATALOADED = 1 and @SEGMENTATIONACTIVE = 0
begin
--Check if the mailing is currently being activated...
declare @R int;
exec @R = dbo.[USP_MKTSEGMENTATION_CHECKACTIVATION] @SEGMENTATIONID;
if @R <> 0
begin
set @DATALOADED = 0;
return 1;
end
end
return 0;