有没有一种方法可以为 Entity Framework 中的可为空的外键关系创建可为空的反向导航属性?用数据库的话来说,是 0..1到0..1 关系。
我尝试了如下操作,但是我不断收到错误消息:
Unable to determine the principal end of an association between the types 'Type1' and 'Type2'. The principal end of this association must be explicitly configured using either the relationship fluent API or data annotations.
public class Type1 {
public int ID { get; set; }
public int? Type2ID { get; set; }
public Type2 Type2 { get; set; }
}
public class Type2 {
public int ID { get; set; }
public int? Type1ID { get; set; }
public Type1 Type1 { get; set; }
}
Type1 Type2
======== ===============
ID ID | Type1ID
-------- ---------------
1 1 | null
2 2 | 2
[ForeignKey],两端使用[InverseProperty]),但似乎都没有帮助。int?属性不是严格必需的,如果有帮助的话。最佳答案
当我读到您的问题时,我想说的是“这不难”。但是我再次发现一对一的联系是奸诈的 SCSS 。开始了。
我假设0..1 – 0..1是指两个对象可以彼此独立存在,但也可以彼此独立关联。
让它具体化。 Car和Driver。想象一下,有很多汽车和驾驶员,其中包括CarA和DriverA。现在,假设您希望CarA与DriverA关联,并且您的实现是DriverA将自己链接到CarA。但是,一旦DriverA这样做,您就希望CarA仅适用于DriverA, CarA的关联不再是可选的,因此也应立即设置它。
如何实现?
选项1:
如果这是工作模型:
public class Car
{
public int CarId { get; set; }
public string Name { get; set; }
public int? DriverId { get; set; }
public virtual Driver Driver { get; set; }
}
public class Driver
{
public int DriverId { get; set; }
public string Name { get; set; }
public int? CarId { get; set; }
public virtual Car Car { get; set; }
}
从技术上讲, DriverA 可以具有 CarA 的外键,而 CarA 可以是 DriverB 的外键。DriverA-CarA时,您应该“同时”建立反向外键CarA-DriverA。那是您应该在代码中执行的操作,这意味着这是业务规则。实际上,这不是原子操作,因此必须确保它是在一个数据库事务中完成的。Driver的映射配置中:this.HasOptional(t => t.Car).WithMany().HasForeignKey(d => d.CarId);
在Car的映射配置中:this.HasOptional(t => t.Driver).WithMany().HasForeignKey(c => c.DriverId);
(没有其他数据注释方法)SaveChanges调用中。CarDriver,该表具有两个外键Car和Driver,这两个外键都包含其唯一的主键:Car和Driver具有指向彼此的集合属性,并且未直接映射联结表:public class Car
{
public int CarId { get; set; }
public string Name { get; set; }
public virtual ICollection<Driver> Drivers { get; set; }
}
public class Driver
{
public int DriverId { get; set; }
public string Name { get; set; }
public virtual ICollection<Car> Cars { get; set; }
}
现在,创建关联是一个原子操作。完全可以使用EF映射此模型。相互引用已消失,但是您仍然可以获取集合属性的FirstOrDefault()作为代理引用。CarDriver中的两列都应具有唯一键,因此每个汽车或驾驶员只能在表中出现一次。通过这些索引,模型本身全部实现了双向可选的1:1关联。任何处理它的代码都必须遵守规则。安然无恙...Car和Driver在数据库中是完全独立的,并且该关联是具有不可空外键的记录(DBA也倾向于这样做)。关于c# - 是否可以在 Entity Framework 中捕获0..1到0..1的关系?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21889367/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html
这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife
我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查
我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下