Ошибка в курсоре хранимой процедуры - PullRequest
0 голосов
/ 28 февраля 2012

В своей хранимой процедуре я объявил «Есть следующие» курсор. Но это дает ошибку между ними.

DECLARE insert_cursor CURSOR FOR 
    select o.orderID, o.paymenttype, o.noOfInstallment, o.installmentPaid,
    p.package_id_pk, p.price
    from order_master as o
    inner join package_master as p ON p.package_id_pk = o.packageID
    where  o.noOfInstallment > 0;

OPEN insert_cursor;
FETCH NEXT FROM insert_cursor
INTO @orderID,@paymenttype,@noOfInstallment,@installmentPaid,@package_id_pk,@price;

WHILE @@FETCH_STATUS = 0
BEGIN
    if(@price = 1)
    begin           
        Declare @paymentID as numeric(18,0), @createdDate datetime
        select @paymentID = paymentID, @createdDate = createdDate from payment_cusotmer where orderID = @orderID
        if(@paymentID is not null)
        begin   
            Declare @pk_free numeric(18,0)          
            set @pk_free = dbo.getUniqueID()

            insert into Order_Installments(ID,orderID,installment_price,duedate,isPaid,createdDate)
            values(@pk_free, @orderID, @price, null, 1,@createdDate)

            update payment_cusotmer set orderInstallment_ID = @pk_free where paymentID = @paymentID
        end         
    end
    else
    begin
        -- 1 = full ; 2 = part payment
        if(@paymenttype = 1)
        begin
        Declare @paymentID_full as numeric(18,0), @createdDate_full datetime,@instDate_full datetime, @amountPaid numeric(18,2),@AmountToPay numeric(18,2), @paidStatus int

        select @paymentID_full = paymentID, @instDate_full = InstDate, @createdDate_full = CreatedDate,
        @paidStatus = status ,@AmountToPay = AmountToPay, @amountPaid=AmountPaid
        from payment_cusotmer where orderID = @orderID

        -- @paidStatus : 1=paid, 2=not paid

        if(@paymentID_full is not null)
        begin   
            Declare @pk_full numeric(18,0)          
            set @pk_full = dbo.getUniqueID()

            insert into Order_Installments(ID,orderID,installment_price,duedate,isPaid,createdDate)
            values(@pk_full, @orderID, @price, @instDate_full, @paidStatus,@createdDate_full)

            update payment_cusotmer set orderInstallment_ID = @pk_full where paymentID = @paymentID
        end 
        end
        else if(@paymenttype = 2)
        begin
            Declare @cnt_invoices int, @cnt_invoices_temp int,@oneTime_payment numeric(18,0), @noOfInstallment_temp int
            select @cnt_invoices = COUNT(PaymentID) from Payment_Cusotmer where  OrderID=@orderID

            Declare @paymentID_part as numeric(18,0), @createdDate_part datetime,@instDate_part datetime, @amountPaid_part numeric(18,2),@AmountToPay_part numeric(18,2), @paidStatus_part int

            set @oneTime_payment = @price/@noOfInstallment;             
            set @cnt_invoices_temp = @cnt_invoices
            while(@cnt_invoices > 0)
            begin
                select @paymentID_part = paymentID, @instDate_part = InstDate, @createdDate_part = CreatedDate,
                @paidStatus_part = status ,@AmountToPay_part = AmountToPay, @amountPaid_part =AmountPaid
                from payment_cusotmer where orderID = @orderID

                -- @paidStatus : 1=paid, 2=not paid

                if(@paymentID_part is not null)
                begin   
                    Declare @pk_part numeric(18,0)
                    set @pk_part = dbo.getUniqueID()

                    insert into Order_Installments(ID,orderID,installment_price,duedate,isPaid,createdDate)
                    values(@pk_part, @orderID, @AmountToPay_part, @instDate_part, @paidStatus_part,@createdDate_part)

                    update payment_cusotmer set orderInstallment_ID = @pk_part where paymentID = @paymentID_part
                end 
                set @cnt_invoices = @cnt_invoices - 1;
            end
            Declare @cnt_remaining_installments int
            set @cnt_remaining_installments = @noOfInstallment - @cnt_invoices;
            if(@cnt_remaining_installments > 0)
            begin
                set @cnt_invoices_temp = @cnt_remaining_installments
                while(@cnt_invoices_temp > 0)
                begin
                    --@oneTime_payment
                    Declare @pk_part_new numeric(18,0)
                    set @pk_part_new = dbo.getUniqueID()

                    insert into Order_Installments(ID,orderID,installment_price,duedate,isPaid,createdDate)
                    values(@pk_part_new, @orderID, @oneTime_payment, null, 0,GETDATE()) 
                    set @cnt_invoices_temp = @cnt_invoices_temp - 1;
                end
            end
        end
    end
    FETCH NEXT FROM insert_cursor
    INTO @orderID,@paymenttype,@noOfInstallment,@installmentPaid,@package_id_pk,@price;
END
CLOSE insert_cursor;
DEALLOCATE insert_cursor; 

Ошибка:

Нарушение ограничения PRIMARY KEY 'PK_Order_Installments'. Не могу вставьте дубликат ключа в объект 'dbo.Order_Installments'.

ПРИМЕЧАНИЕ. У меня есть функция sql GetuniqueID(), которая возвращает uniqueID.

Я думаю, проблема не в вышеуказанной функции. Проблема с областью действия локальной переменной.

Функция SQL GetUniqueID ()

select @RandomMilliSecond= convert(nvarchar,datepart(ms,theDATE)) from v_getdate
select @RandomSecond=convert(nvarchar,datepart(ss,theDATE)) from v_getdate 
select @RandomYear=convert(nvarchar,datepart(yy,theDATE)) from v_getdate 
select @RandomMonth=convert(nvarchar,datepart(mm,theDATE)) from v_getdate 
select @RandomDay=convert(nvarchar,datepart(dd,theDATE)) from v_getdate
select @RandomHr=convert(nvarchar,datepart(hh,theDATE)) from v_getdate 
select @RandomMin=convert(nvarchar,datepart(mi,theDATE)) from v_getdate 
set @TMpReturnValue = @RandomYear + @RandomMonth
set @TMpReturnValue = @TMpReturnValue + @RandomDay + @RandomHr
set @TMpReturnValue = @TMpReturnValue + @RandomMin  + @RandomSecond
set @TMpReturnValue = @TMpReturnValue + @RandomMilliSecond
set @ReturnValue = @TMpReturnValue
return @ReturnValue
...