前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >entity framework数据库映射

entity framework数据库映射

作者头像
sofu456
发布2019-12-03 11:44:06
9460
发布2019-12-03 11:44:06
举报
文章被收录于专栏:sofu456

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

三种开发模式

ORM框架的对象关系映射

  • DataBase First (数据库优先,还没写代码)
  • Model First (模型优先edmx文件,数据库表未创建)
  • Code First (代码优先)

Sql Server安装:EntityFramework Mysql安装:MySql.Data.Entity

数据库优先

选择ADO.NET实体对象,

  • 来自数据库的EF设计器 导入数据库结构

模型优先

选择ADO.NET实体对象,创建edmx文件,需要安装vs数据库连接插件或者odbc驱动

  • 空EF设计器
在这里插入图片描述
在这里插入图片描述

右键菜单中,验证有无错误,连接数据库生成表数据

在这里插入图片描述
在这里插入图片描述

添加代码生成项,创建模型DBContext代码

代码语言:javascript
复制
using (Model1Container mc = new Model1Container())
{
     mc.BlogsSet.Add(new Blogs()
     {
         Id = 1,
         Name = "hello",
         Title = "world"
     });
     mc.SaveChanges();
 }    

代码优先

选择ADO.NET实体对象,

  • 空的Code first设计器 或者自己添加cs代码
代码语言:javascript
复制
	public class Blog
    {
        public int BlogId { get; set; }
        public string Title { get; set; }
        public DateTime CreateDate { get; set; }
    }
    [DbConfigurationType(typeof(MySqlEFConfiguration))]
    public class BlogEntities : DbContext
    {
    	public BlogEntities():base("name=mysqltest") { }     //mysqltest是app.config中的key name
        public DbSet<Blog> Blogs { get; set; }
    }

创建数据库

代码语言:javascript
复制
	using(BlogEntities blog = new BlogEntities())
    {
        blog.Blogs.Add(new Blog() {
            BlogId = 1,
            Title = "test",
            CreateDate = DateTime.Now
        });
        blog.SaveChanges();
    }

nuget添加EntityFramework后,配置文件App.config文件中配置数据库连接

代码语言:javascript
复制
    <entityFramework>
        <providers>
            <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer"/>
        </providers>
    </entityFramework>

添加连接字符串

代码语言:javascript
复制
<connectionStrings>
    <add name="mysqltest" connectionString="Data Source=localhost;port=3306;Initial Catalog=mysql;user id=root;password=root;" providerName="MySql.Data.MySqlClient" />
</connectionStrings>

ef自动创建数据库和表,在已有数据库中需要创建结构一致的表(这个操作和code first违背)

参考

https://www.cnblogs.com/1312mn/p/9239419.html

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/11/26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 三种开发模式
  • 数据库优先
  • 模型优先
  • 代码优先
  • 参考
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档