EFCodeFirst快速搭建入门
EFCodeFirst快速搭建入门
1.新建Model类库项目。
添加EntityFramework.dll的引用。
编写实体类Course,Student。
namespace EFCodeFirst.Model { public class Course { [Key] public int Id { get; set; } [Required] [StringLength(50)] public string Name { get; set; } } }
namespace EFCodeFirst.Model { public class Student { [Key] public int Id { get; set; } [Required] [StringLength(20)] public string Name { get; set; } public Course Course { get; set; } } }
ps:Key是主键。
2.编写EF上下文StudentInfoEntities类。
namespace EFCodeFirst.Model { public class StudentInfoEntities:DbContext { public DbSet<Course> Course { get; set; } public DbSet<Student> Student { get; set; } } }
3.新建控制台项目
在配置文件中加入上下文的连接字符串的信息。
<?xml version="1.0" encoding="utf-8" ?> <configuration> <connectionStrings> <add name="StudentInfoEntities" connectionString="Data Source=.\;Initial Catalog=StudentInfo;Integrated Security=True" providerName="System.Data.SqlClient"/> </connectionStrings> </configuration>
4.在主程序代码中调用
调用方式和EFModelFirst一致,详细参见 http://www.cnblogs.com/sunniest/p/4138291.html,第一次运行时EF会自动生成数据库(包括外键等信息)。
namespace EFCodeFirst { class Program { static StudentInfoEntities db = new StudentInfoEntities(); static void Main(string[] args) { Course co = db.Course.Where(u=>u.Name=="语文").FirstOrDefault(); db.Student.Add(new Student() { Name = "jayjay", Course = co }); db.SaveChanges(); Console.ReadKey(); } } }
生成数据库的结构如图。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?