USP_DATAFORMTEMPLATE_ADD_PRICE

The save procedure used by the add dataform template "Price Add Data Form".

Parameters

Parameter Parameter Type Mode Description
@ID uniqueidentifier INOUT The output parameter indicating the ID of the record added.
@CONTEXTID uniqueidentifier IN Input parameter indicating the context ID for the record being added.
@PRICELISTID uniqueidentifier IN Price list
@CHANGEAGENTID uniqueidentifier IN Input parameter indicating the ID of the change agent invoking the procedure.
@PRICETYPECODEID uniqueidentifier IN Price type
@FACEPRICE money IN Face price

Definition

Copy


                CREATE procedure dbo.USP_DATAFORMTEMPLATE_ADD_PRICE
                (
                    @ID uniqueidentifier = null output,
                    @CONTEXTID uniqueidentifier,
                    @PRICELISTID uniqueidentifier,
                    @CHANGEAGENTID uniqueidentifier = null,
                    @PRICETYPECODEID uniqueidentifier = null,
                    @FACEPRICE money = null
                )
                as

                set nocount on;

                if @ID is null
                    set @ID = newid()

                if @CHANGEAGENTID is null  
                    exec dbo.USP_CHANGEAGENT_GETORCREATECHANGEAGENT @CHANGEAGENTID output

                declare @CURRENTDATE datetime
                set @CURRENTDATE = getdate()

                declare @SEQUENCE int

                if exists(select ID from dbo.PRICE where PRICELISTID = @CONTEXTID)
                    select @SEQUENCE = max(SEQUENCE) + 1
                    from dbo.PRICE
                    where PRICELISTID = @CONTEXTID
                else
                    set @SEQUENCE = 1


                begin try
                    insert into dbo.PRICE
                    (
                        ID, 
                        PRICELISTID,
                        PRICETYPECODEID, 
                        FACEPRICE, 
                        SEQUENCE,
                        ADDEDBYID, 
                        CHANGEDBYID, 
                        DATEADDED, 
                        DATECHANGED
                    )
                    values
                    (
                        @ID
                        @PRICELISTID
                        @PRICETYPECODEID
                        @FACEPRICE
                        @SEQUENCE,
                        @CHANGEAGENTID
                        @CHANGEAGENTID
                        @CURRENTDATE
                        @CURRENTDATE
                    )
                end try

                begin catch
                        exec dbo.USP_RAISE_ERROR
                        return 1
                end catch

                return 0