USP_DATAFORMTEMPLATE_EDITLOAD_PREPROCESS_BILLINGGENERATETRANSACTIONSCHARGE

The load procedure used by the edit dataform template "Billing Generate Transactions Charge Preprocess Edit Data Form"

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.
@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.
@NAME nvarchar(100) INOUT Name
@TRANSACTIONTYPE nvarchar(255) INOUT Type
@BILLINGITEMS nvarchar(4000) INOUT Selected billing items
@TRANSACTIONDATE date INOUT Transaction date
@CREATEOUTPUTIDSET bit INOUT Create selection from results
@OUTPUTSELECTIONTYPEID uniqueidentifier INOUT Selection type
@OUTPUTSELECTIONNAME nvarchar(100) INOUT Selection name
@OVERWRITEOUTPUTSELECTION bit INOUT Overwrite existing selection
@CREATEEXCEPTIONIDSET bit INOUT Create selection from results
@EXCEPTIONSELECTIONTYPEID uniqueidentifier INOUT Selection type
@EXCEPTIONSELECTIONNAME nvarchar(100) INOUT Selection name
@OVERWRITEEXCEPTIONSELECTION bit INOUT Overwrite existing selection
@RECORDTYPEID uniqueidentifier INOUT
@SCHOOLS xml INOUT Generate charges for

Definition

Copy


CREATE procedure dbo.USP_DATAFORMTEMPLATE_EDITLOAD_PREPROCESS_BILLINGGENERATETRANSACTIONSCHARGE(
    @ID uniqueidentifier,
    @DATALOADED bit = 0 output,
    @TSLONG bigint = 0 output,
    @NAME nvarchar(100) = null output,
    @TRANSACTIONTYPE nvarchar(255) = null output,
    @BILLINGITEMS nvarchar(4000) = null output,
    @TRANSACTIONDATE date = null output,
    @CREATEOUTPUTIDSET bit = null output,
    @OUTPUTSELECTIONTYPEID uniqueidentifier = null output,
    @OUTPUTSELECTIONNAME nvarchar(100) = null output,
    @OVERWRITEOUTPUTSELECTION bit = null output,
    @CREATEEXCEPTIONIDSET bit = null output,
    @EXCEPTIONSELECTIONTYPEID uniqueidentifier = null output,
    @EXCEPTIONSELECTIONNAME nvarchar(100) = null output,
    @OVERWRITEEXCEPTIONSELECTION bit = null output,
    @RECORDTYPEID uniqueidentifier = null output,
    @SCHOOLS xml = null output
)
as

    set nocount on;

    -- be sure to set these, in case the select returns no rows

    set @DATALOADED = 0
    set @TSLONG = 0

    -- populate the output parameters, which correspond to fields on the form.  Note that

    -- we set @DATALOADED = 1 to indicate that the load was successful.  Otherwise, the system

    -- will display a "no data loaded" message.  Also note that we fetch the TSLONG so that concurrency

    -- can be considered.

    select
        @DATALOADED = 1,
        @TSLONG = TSLONG,
        @NAME = NAME,
        @TRANSACTIONTYPE = TRANSACTIONTYPE,
        @TRANSACTIONDATE = TRANSACTIONDATE,
        @CREATEOUTPUTIDSET = CREATEOUTPUTIDSET,
        @OUTPUTSELECTIONTYPEID = OUTPUTSELECTIONTYPEID,
        @OUTPUTSELECTIONNAME = OUTPUTSELECTIONNAME,
        @OVERWRITEOUTPUTSELECTION = OVERWRITEOUTPUTSELECTION,
        @CREATEEXCEPTIONIDSET = CREATEEXCEPTIONIDSET,
        @EXCEPTIONSELECTIONTYPEID = EXCEPTIONSELECTIONTYPEID,
        @EXCEPTIONSELECTIONNAME = EXCEPTIONSELECTIONNAME,
        @OVERWRITEEXCEPTIONSELECTION = OVERWRITEEXCEPTIONSELECTION,
        @SCHOOLS = dbo.UFN_BILLINGGENERATETRANSACTIONSPROCESS_GETSCHOOLS_TOITEMLISTXML(@ID)
    from dbo.BILLINGGENERATETRANSACTIONSPROCESS
    where ID = @ID

    select @BILLINGITEMS = coalesce(@BILLINGITEMS + ', ', '') + NAME
    from dbo.BILLINGGENERATETRANSACTIONSCHARGEPROCESSBILLINGITEMS PROCESSBILLINGITEMS
        inner join dbo.BILLINGITEM on PROCESSBILLINGITEMS.BILLINGITEMID = BILLINGITEM.ID
    where PROCESSBILLINGITEMS.BILLINGGENERATETRANSACTIONSPROCESSID = @ID

    select @RECORDTYPEID = ID from dbo.RECORDTYPE where upper(NAME) = 'STUDENT'

    return 0;