2012-11-18 78 views
0

我用C#winforms和SQL服务器和LINQ to SQL编写了程序。我使用用户控件而不是表单。在我的用户控件中,我放置了3个文本框,txtStartNumber,txtEndNumber,txtQuantity。用户定义文本框的值,当点击按钮时,它会根据txtQuantity的值插入一些记录。在数据库中添加重复记录后显示消息

我想创建重复号码时,它不会添加到数据库和显示消息。 我该怎么办?我必须在代码后面或服务器端编写代码?我必须在存储过程中设置此值或触发器?

private void btnSave_Click(object sender, EventArgs e) 
     { 
      long from = Convert.ToInt64(txt_barcode_f.Text); 
      long to = Convert.ToInt64(txt_barcode_t.Text); 
      long quantity = Convert.ToInt64(to - from); 
      int card_Type_ID=Convert.ToInt32(cmb_BracodeType .SelectedValue); 
      long[] arrCardNum = new long[(to - from)]; 

      arrCardNum[0]=from; 

      for (long i = from; i < to; i++) 
      { 
       for(int j=0; j<(to-from) ;j++) 
       { 
       arrCardNum[j]=from+j; 
       string r = arrCardNum[j].ToString(); 
       sp.SaveCards(r, 2, card_Type_ID, SaveDate, 2); 
       } 
      } 
     } 

存储过程代码。

ALTER PROCEDURE dbo.SaveCards 
@Barcode_Num int 
,@Card_Status_ID int 
,@Card_Type_ID int 
,@SaveDate varchar(10) 
,@Save_User_ID int 


AS 

BEGIN 
INSERT INTO [Parking].[dbo].[TBL_Cards] 
      ([Barcode_Num] 
      ,[Card_Status_ID] 
      ,[Card_Type_ID]  
      ,[Save_User_ID]) 

    VALUES 
      (@Barcode_Num 
      ,@Card_Status_ID 
      ,@Card_Type_ID 
      ,@Save_User_ID) 


    END 
+0

目前当你点击btnsave按钮,此时它被存储在数据库或?。 –

回答

0

如果您正确设置数据库,任何尝试添加重复密钥都会引发异常。您可以捕获该异常以查看是否是尝试添加重复密钥的结果。
例如:

try 
{ 
    sp.SaveCards(r, 2, card_Type_ID, SaveDate, 2); 
} 
catch (SqlException e) 
{ 
    // Check if exception was raised because of a duplicate key and perform your logic 
} 
catch (Exception ex) 
{ 
    // Any other exceptions raised 
} 

你提到LINQ,所以我建议你也阅读有关DuplicateKeyException例外。

+0

如何防止用户在数据库中插入重复字段? – user1770370

+0

这里,在我的代码,没有比较记录与以前的记录存储在数据库中 – user1770370

+0

我不明白你在问什么。如果尝试在不允许重复的字段上添加重复字段,此代码将会发出异常。为什么这对你不够好?在INSERT之前,您始终可以选择SELECT以检查值是否已存在,但这可能会导致多客户端应用程序中的竞争状况。 – Blachshma

0

如果您要将数据存储在sql server中,那么您可以为TBL_Cards表中的条形码num columen创建集PRIMARY KEY。你可以通过使用duplicatekeyException显示错误消息,或者在存储过程中使用RAISEERROR

希望这有助于