首页 技术 正文
技术 2022年11月13日
0 收藏 448 点赞 5,055 浏览 1631 个字

声明方式

 public class Photograph
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int PhotoId { get; set; }
public string Title { get; set; }
public byte[] ThumbnailBits { get; set; }
[ForeignKey("PhotoId")]
public virtual PhotographFullImage PhotographFullImage { get; set; }
} public class PhotographFullImage
{
[Key]
public int PhotoId { get; set; }
public byte[] HighResolutionBits { get; set; }
[ForeignKey("PhotoId")]
public virtual Photograph Photograph { get; set; }
} public class PhotoContext : DbContext
{
public DbSet<Photograph> Photographs { get; set; }
public DbSet<PhotographFullImage> PhotographFullImages { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<Photograph>()
//配置必需关系。 数据库中的外键不可为 null否则无法保存到数据库。
.HasRequired(p => p.PhotographFullImage)
//作为关系目标的主体类型将成为依赖对象,且包含主体的外键
.WithRequiredPrincipal(p => p.Photograph);
modelBuilder.Entity<Photograph>().ToTable("Table1");
modelBuilder.Entity<PhotographFullImage>().ToTable("Table2");
}
}

怎么使用

  static void Main(string[] args)
{
var thumbBits = new byte[];
var fullBits = new byte[];
using (var context = new PhotoContext())
{
var photo = new Photograph
{
Title = "小狗",
ThumbnailBits = thumbBits
};
var fullImage = new PhotographFullImage { HighResolutionBits = fullBits };
photo.PhotographFullImage = fullImage;
context.Photographs.Add(photo);
context.SaveChanges();
}
using (var context = new PhotoContext())
{
foreach (var photo in context.Photographs)
{
Console.WriteLine("照片: {0}, 压缩 {1} bytes",
photo.Title, photo.ThumbnailBits.Length);
// 显式地加载了“昂贵”的实体
context.Entry(photo).Reference(p => p.PhotographFullImage).Load();
Console.WriteLine("原始: {0} bytes",
photo.PhotographFullImage.HighResolutionBits.Length);
}
Console.ReadKey();
}
}

生成实体结构

分割一个表到多个实体<EntityFramework6.0>

运行效果

分割一个表到多个实体<EntityFramework6.0>

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,085
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,560
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,409
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,182
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,819
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,902