Исключение числа транзакций в vb.net (исключение SQL) - PullRequest
0 голосов
/ 27 ноября 2009

Я получаю ниже исключения, когда я собираюсь ввести запись в таблицу через StoredProceduer из sqlserver У меня есть поле, которое мне нужно обновить сразу после вставки новой записи в таблицу. для этого я создал sotredprocedure, в котором я сначала написал команду вставки, а после этого я написал команду обновления для того же записанного, но он дал мне ошибку ниже SqlException: Число транзакций после EXECUTE указывает на несовпадающее количество операторов BEGIN и COMMIT. Предыдущий счетчик = 1, текущий счетчик = 2. В конце пакета обнаружена незафиксированная транзакция. Сделка откатывается. Некоторая ошибка при выполнении хранимой процедуры

я пробовал другим способом, например: я просто написал команду вставки в хранимой процедуре и создал триггер afterInsert, в котором запускаю команду обновления. но все же я стою перед исключением

Подробнее: Структура таблицы:

CREATE TABLE [dbo].[TabStoreGRNMaster](
    [pk_grnm_id] [bigint] IDENTITY(1,1) NOT NULL,
    [fk_col_id] [bigint] NULL,
    [fk_sup_id] [bigint] NULL,
    [grnm_grnno] [varchar](50) NULL,
    [grnm_date] [nvarchar](10) NULL,
    [grnm_partyinvno] [varchar](50) NULL,
    [grnm_invdate] [nvarchar](10) NULL,
    [grnm_freight] [numeric](7, 2) NULL,
    [grnm_otherchrg] [numeric](7, 2) NULL,
    [grnm_roundoff] [bit] NULL,
    [Fk_User_Id] [bigint] NULL,
    [grnm_EntryDate] [nvarchar](8) NULL,
 CONSTRAINT [PK_TabStoreGRNMaster] PRIMARY KEY CLUSTERED 
(
    [pk_grnm_id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

StoredProcedure:

USE [Kollege]
GO
/****** Object:  StoredProcedure [dbo].[StoreGRNMaster]    Script Date: 11/27/2009 10:20:37 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[StoreGRNMaster]
    (
    @pk_grnm_id         [bigint] output ,
    @fk_col_id          [bigint] = 0 ,
    @fk_sup_id          [bigint] = 0 ,
    @grnm_grnno         [varchar](50) = '',
    @grnm_date          [nvarchar](10) = null,
    @grnm_partyinvno            [varchar](50) = '',
    @grnm_invdate           [nvarchar](10) = null,
    @grnm_freight           [numeric] = 0 ,
    @grnm_otherchrg         [numeric] = 0 ,
    @grnm_roundoff          [bit] = 0 ,
    @Fk_User_Id         [bigint] = 0 ,
    @grnm_EntryDate         [nvarchar](8) = null,
    @opt                        [BIGINT] =0,
    @del                        [bit] =0

    )
 as 
 begin 
 SET NOCOUNT ON; 
 BEGIN TRY 
 begin transaction 
 if isnull(@opt,0) = 0 begin
 INSERT INTO TabStoreGRNMaster
    (
    fk_col_id,
    fk_sup_id,
    grnm_grnno,
    grnm_date,
    grnm_partyinvno,
    grnm_invdate,
    grnm_freight,
    grnm_otherchrg,
    grnm_roundoff,
    Fk_User_Id,
    grnm_EntryDate
    )
VALUES
    (
    @fk_col_id,
    @fk_sup_id,
    @grnm_grnno,
    @grnm_date,
    @grnm_partyinvno,
    @grnm_invdate,
    @grnm_freight,
    @grnm_otherchrg,
    @grnm_roundoff,
    @Fk_User_Id,
    @grnm_EntryDate
    )
set @pk_grnm_id = @@identity 
 end 
 else 
 begin 
 if @del = 0 
 UPDATE TabStoreGRNMaster
SET
        fk_col_id           =   @fk_col_id,
        fk_sup_id           =   @fk_sup_id,
        grnm_grnno          =   @grnm_grnno,
        grnm_date           =   @grnm_date,
        grnm_partyinvno         =   @grnm_partyinvno,
        grnm_invdate            =   @grnm_invdate,
        grnm_freight            =   @grnm_freight,
        grnm_otherchrg          =   @grnm_otherchrg,
        grnm_roundoff           =   @grnm_roundoff,
        Fk_User_Id          =   @Fk_User_Id,
        grnm_EntryDate          =   @grnm_EntryDate
WHERE
(
pk_grnm_id  =   @opt
)  

if @del=1 and isnull(@opt,0) <> 0 

 DELETE from [TabStoreGRNMaster]
WHERE
    ( [pk_grnm_id]   = @opt)
end 
 commit transaction 
 END TRY 
 BEGIN CATCH 
 raiserror ('Some Error in stored procedure execution',1,1) 
 END CATCH; 
 END 

Trigger:

alter TRIGGER TGRStoreGRNMasterCode
ON tabStoreGRNMaster
AFTER INSERT 
AS
begin
declare @pk varchar(10)
declare @colcode varchar(10)
declare @current_session varchar(20)
declare @colid bigint
set @pk  = (select pk_grnm_id from Inserted)
--set @colid = (select fk_col_id from Inserted)
set @colcode= 'jiet'--(select col_code from tabcollegemaster where pk_col_id =5)  (when i replace word 'Jiet' with commented qry i gets sql exception otherwise its working fine)
select @current_session = Ses_abbrev  from TabAcaSessionMast where ses_current = 1 
--update tabStoreGRNMaster set grnm_grnno= @colcode +'/' +@current_session+ '/' + @pk where pk_grnm_id=convert(bigint,@pk)
update tabStoreGRNMaster set grnm_grnno= (select col_code from tabcollegemaster where pk_col_id=5) +'/' +@current_session+ '/' + @pk where pk_grnm_id=convert(bigint,@pk)

end

Ответы [ 2 ]

0 голосов
/ 13 декабря 2009

В вашем комментарии к другому ответу упоминается "Я поддерживаю транзакции с Vb.net также во время вызова этой хранимой процедуры". Это причина

Вы должны сбалансировать ваши BEGIN TRAN и COMMITs / ROLLBACKs, чтобы @@ TRANCOUNT начинался и заканчивался с одинаковым значением для той же области.

Либо делайте все это в хранимой процедуре, либо все это в клиенте

0 голосов
/ 27 ноября 2009

Мне кажется, что вы ничего не делаете с открытой транзакцией, если в вашем блоке TRY обнаружена ошибка - COMMIT не запустится, но ваш блок CATCH не имеет ROLLBACK.

...