首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >来自dbml的UpdateOnSubmit?

来自dbml的UpdateOnSubmit?
EN

Stack Overflow用户
提问于 2013-11-27 10:28:07
回答 2查看 1.1K关注 0票数 3

我有一些生成的类表示dbml文件中的表。

在表中插入记录可以以名称作为主键。

代码语言:javascript
复制
  dbDataContext nc = new dbDataContext(connectionstring);

  Action action = new Action();
  action.Name = "1234"; // primary key

  nc.Actions.InsertOnSubmit(action);
  nc.SubmitChanges();

但是,当名称已经存在时,如何更新记录呢?似乎没有UpdateOnSubmit之类的东西。这个问题似乎没有一个明确的答案。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-11-27 10:36:03

首先,您需要从数据库中获取记录,然后在该对象中执行更新并保存更改。

代码语言:javascript
复制
Action action = nc.Actions.FristOrDefault(e=>e.Name="1234");

if(action!=null)
{
  action.SomeOtherProperty="NewValue";
}

nc.SubmitChanges();
票数 3
EN

Stack Overflow用户

发布于 2013-11-27 10:46:41

同时处理添加和更新的情况

代码语言:javascript
复制
public void Persist(Company company)
{
  var companyInDb = _dbSet.SingleOrDefault(c => c.Id == company.Id);
  if (companyInDb != null)
  {
    _context.Entry(companyInDb).CurrentValues.SetValues(company);
  }
   else
  {
    _dbSet.Add(company);
  }
    _context.SaveChanges();
 }
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20239869

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档