[LINQ]数据存在时Update,不存在则Insert

最近帮朋友做一个报名站,非常简单,于是拿.NET 3.5特别是LINQ to SQL来练练手。

一切顺利,唯独遇到一个小问题:有些记录,我只想每个用户在数据库中只拥有一条记录,如果数据库中已经存在记录,则用新的内容对原数据UPDATE,没有的话则INSERT。利用异常处理走了个小偏门,感觉不能算是正统的办法,希望哪位看到给指导一下。


代码如下:

 1 public   partial   class  Test : System.Web.UI.Page
 2 ExpandedBlockStart.gifContractedBlock.gif {
 3protected void InsertOrUpdateDate()
 4ExpandedSubBlockStart.gifContractedSubBlock.gif{
 5    GraduateRegisterDataContext context = new GraduateRegisterDataContext(StaticData.ConnectionString);
 6ExpandedSubBlockStart.gifContractedSubBlock.gif    try {
 7        // 记录存在,检索后修改ProvinceOf值为2
 8        FamilyInfo family = context.FamilyInfo.Single(f => f.NationalId == "3");
 9        family.ProvinceOf = "200";
10    }

11ExpandedSubBlockStart.gifContractedSubBlock.gif    catch (InvalidOperationException inex) {
12        // 记录不存在,触发InvalidOperationException异常,创建新对象后插入
13ExpandedSubBlockStart.gifContractedSubBlock.gif        FamilyInfo family = new FamilyInfo {
14            Address = "1",
15            ApplyReason = "1",
16            CityOf = "1",
17            NationalId = "3",
18            DistrictOf = "1",
19            FinacialStatus = "1",
20            IsApplyGrant = true,
21            ZipCode = "1",
22            ProvinceOf = "1"
23        }
;
24        context.FamilyInfo.InsertOnSubmit(family);
25    }

26ExpandedSubBlockStart.gifContractedSubBlock.gif    finally {
27        context.SubmitChanges();
28    }

29}

 

转载于:https://www.cnblogs.com/AntiGameZ/archive/2008/08/03/1259417.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值