Entity FrameWork对有外键关联的数据表的添加操作

时间:2022-02-02 08:30:36

前天做了一个MVC Entity FrameWork项目,遇到有外键关联的数据编辑问题。当你编辑的时候,按照正常的逻辑,把每个字段的数据都对号入座了,然后点击保存按钮,本以为会顺理成章的编辑数据,但是EF却与众不同,它就是不如你所愿,当你查看数据列表的时候,你会发现列表中莫名其妙的又多了一条数据。很是蛋疼啊。

实体类

    public class DeviceViewControl
{
public int ID { get; set; } //控件ID
public DeviceView DeviceView { get; set; } //所在视图ID
public DeviceSensorPoint DeviceSensorPoint { get; set; } //对应感控点ID
public string ViewControlClassName { get; set; } //控件类名称
public string ViewControlPosition { get; set; } //控件位置
public string Remark { get; set; } //备注
}

实体类1(主键表)

    public class DeviceView
{
public Device deviceID { get; set; } //所属设备ID
public int ID { get; set; } //视图ID
public string Code { get; set; } //视图编码
public string viewName { get; set; } //视图类名称
}

实体类2(外键表)

  public class DeviceSensorPoint
{
public int ID { get; set; }
public Device deviceID { get; set; } //设备ID
public string EnglishName { get; set; } //感控点名称(英文)
public string OldEnglishName { get; set; } //原有感控点名称(英文)
public string ChineseName { get; set; } //中文感控点名称
public string ValueType { get; set; } //数据类型(Analog/Switch)
public Nullable<bool> Readable { get; set; } //是否可读
public Nullable<bool> Writeable { get; set; } //是否可写
public Nullable<decimal> RecommandValue { get; set; } //推荐值
public Nullable<decimal> WriteValue { get; set; } //写入值
public Nullable<bool> IsWriten { get; set; } //是否写入
public Nullable<int> PLCReadChannelNo { get; set; } //读通道号
public Nullable<int> PLCWriteChannelNo { get; set; } //写通道号
public string SwitchNameOfTrue { get; set; } //开关量True代表的含义
public string SwitchNameOfFalse { get; set; } //开关量False代表的含义
public Nullable<decimal> MaxValue { get; set; } //量程上限
public Nullable<decimal> MinValue { get; set; } //量程下限
public bool IsAlarmNeeded { get; set; } //是否开启报警
public string Unit { get; set; } //计量单位
public Nullable<decimal> AlarmUpperValue { get; set; } //报警上限
public Nullable<decimal> AlarmLowerValue { get; set; } //报警下限
public string AlarmUpperInfo { get; set; } //报警上限提示信息
public string AlarmLowerInfo { get; set; } //报警下限提示信息
public string Remark { get; set; } //备注
public Nullable<decimal> CurrentValue { get; set; }
}

实体类3(外键表)

实现方法:

原来实现的是直接把ID(外键关联)赋予外键,但是发现这样是不行的。会出现开篇时候所说的效果。就想了如下解决办法。

   [HttpPost]
public ActionResult Edit(string deviceViewCode, DAL.DeviceViewControl deviceViewControl,int Id)
{
if (!ModelState.IsValid)
{
if (string.IsNullOrEmpty(deviceViewControl.ViewControlClassName))
{
ModelState.AddModelError("ViewControlClassName", "请输入控件类名");
}
} //获取视图
var deviceView = this.db.DeviceViews.Where(p => p.Code == deviceViewCode).FirstOrDefault(); //获取感控点
var deviceSeneorPoint = db.DeviceSensorPoints.Where(p => p.ID == deviceViewControl.DeviceSensorPoint.ID).FirstOrDefault(); //获取控件
var deviceControl = db.DeviceViewControls.Where(p => p.ID == Id).FirstOrDefault();
deviceControl.Remark = deviceViewControl.Remark;
deviceControl.ViewControlClassName = deviceViewControl.ViewControlClassName;
deviceControl.DeviceSensorPoint = deviceSeneorPoint;
this.db.SaveChanges(); return RedirectToAction("List", new { deviceViewCode = deviceViewCode });
}

实现编辑

解决办法:就是先获取外键表的实体,将实体数据赋予要编辑表的外键。这样的话,实现主外键关联。真正实现编辑,而不是编辑变添加。

Entity FrameWork对有外键关联的数据表的添加操作的更多相关文章

  1. SQLSERVER清空&lpar;Truncate&rpar;被外键引用的数据表

    前言:我们知道SQLSERVER清空数据表有两种方式Delete和Truncate,当然两者的不同大家也都知道(不清楚的可以MSDN).不过这个错误“Cannot truncate table  be ...

  2. MySQL:如何导入导出数据表和如何清空有外建关联的数据表

    1.导入导出 导入数据库:前提:数据库和数据表要存在(已经被创建) (1)将数据表 test_user.sql 导入到test 数据库的test_user 表中 [root@test ~]# mysq ...

  3. Entity Framework 更新带外键的实体为null

    using (var ctx = new PortalContext()){    var city = ctx.Cities.Find(42);    ctx.Entry(city)        ...

  4. Rails中关联数据表的添加操作(嵌套表单)

    很早就听说有Web敏捷开发这回事,最近终于闲了下来,可以利用业余的时间学些新东西,入眼的第一个东东自然是Ruby on Rails.Rails中的核心要素也就是MVC.ORM这些了,因此关于Rails ...

  5. 《Entity Framework 6 Recipes》中文翻译系列 &lpar;29&rpar; ------ 第五章 加载实体和导航属性之过滤预先加载的实体集合和修改外键关联

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-13  过滤预先加载的实体集合 问题 你想过滤预先加载的实体集合,另外,你想使用 ...

  6. Mysql中的外键分析&lpar;什么是外键&comma;为什么要用外键&comma;添加外键,主外键关联删除&rpar;

    有一个东西一直在我脑海中是个很烦的东西,但是这东西不搞清楚会阻碍自己的前进.自己做项目demo永远只能用一张表... 所以今天还是学习了下外键希望能够搞明白一些... 百度上搜索外键的作用" ...

  7. mysql 外键关联

    mysql 外键关联 什么是外键:外键是一个特殊的索引,用于关联两个表,只能是指定内容. 如我将新建一个daka的表,然后将此表的class_id 与另外一个class的表的cid字段关联 class ...

  8. sql操作数据库(3)--&gt&semi;外键约束、数据库表之间的关系、三大范式、多表查询、事务

    外键约束 在新表中添加外键约束语法: constraint 外键约束名称 foreign key(外键的字段名称) references 主表表名(主键字段名) 在已有表中添加外键约束:alter t ...

  9. 【MySQL】MySQL进阶(外键约束、多表查询、视图、备份与恢复)

    约束 外键约束 外键约束概念 让表和表之间产生关系,从而保证数据的准确性! 建表时添加外键约束 为什么要有外键约束 -- 创建db2数据库 CREATE DATABASE db2; -- 使用db2数 ...

随机推荐

  1. List中存储同一个对象(内容不同)

    List中存储同一个对象,前面的会被后存入的对象覆盖,解决方法:每次存入新的对象

  2. 开源游戏 &OpenCurlyDoubleQuote;Elvish Bird”

    简介: 这个游戏是我在今年(2014/03)课余时闲着无聊做的一个冒险类小游戏,总共花了5个工作日才完成,为了游戏的效率,做了很多优化,目前在IE8以上浏览器能够流畅运行,运行时如果屏幕分辨率不兼容, ...

  3. Python自动化之paramiko

    只需要连接一次 import paramiko li = [] ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko. ...

  4. loadrunner工具使用之脚本创建

    loadrunner工具使用之脚本创建 一.创建脚本 1.打开loadrunner,选择第一个控件VuGen(创建/编辑脚本),点击

  5. 可重入锁 &amp&semi; 自旋锁 &amp&semi; Java里的AtomicReference和CAS操作 &amp&semi; Linux mutex不可重入

    之前还是写过蛮多的关于锁的文章的: http://www.cnblogs.com/charlesblc/p/5994162.html <[转载]Java中的锁机制 synchronized &a ...

  6. XACT&lowbar;ABORT 用法

    首先创建一张表 Create Table TranTable(    Id INT IDENTITY(1,1) PRIMARY KEY,    Priority TINYINT--最大值255) 1. ...

  7. 什么是XAML&quest;

    XAML类似于XML一样的一种标记语言,主要用来设计UI. 对于XAML的历史,哪些都是废话了,至于Microsoft怎么整出XAML,然后,又怎么让XAML来开发windows 8应用程序,这些,都 ...

  8. iBeacon开发

    什么是iBeacons iBeacons是苹果在2013年WWDC上推出一项基于蓝牙4.0(Bluetooth LE | BLE | Bluetooth Smart)的精准微定位技术,当你的手持设备靠 ...

  9. Linq 集合操作符 Except&comma;Intersect&comma;Union

    IList<string> s1 = new List<string>() { "One", "Two", "Three&qu ...

  10. select,poll,epoll

    1. Epoll 是何方神圣? Epoll 可是当前在 Linux 下开发大规模并发网络程序的热门人选, Epoll 在 Linux2.6 内核中正式引入,和 select 相似,其实都 I/O 多路 ...