欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

EF使用笔记

发布时间:2025/4/9 编程问答 42 豆豆
生活随笔 收集整理的这篇文章主要介绍了 EF使用笔记 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

  最近写接口导数据到大数据中心,但是实体数据字段非常多,如果手动去建数据库表和写插入语句效率非常低,所以想都试一试EF,效率之高,简直吓人,所以此文详细记录操作过程以备下次使用时之用。仅需六部就可完成建表,插入数据,下面详细介绍如下:

一、引用EntityFramework

  使用nuget快速引用EF框架到API项目中,引用成功后可以看到加入了两个名为:EntityFramework,EntityFramework.sqlserver的包,说明引用成功了,第一步搞定。

二、配置数据库连接字符

  在config文件中,添加connectionStrings标签,然后添加连接数据库的配置,连接字符串名为:DefaultConnection,如下图:

<add name="DefaultConnection" connectionString="Data Source=XXXX;database=XXXX;Uid=XXX;Pwd=XXX;Integrated Security=false;" providerName="System.Data.SqlClient"/>

三、添加数据库关联实体类

  其中appDb():base("name=DefaultConnection")为构造函数,DefaultConnection为数据库连接字符串名,保持和第二步一致就行。下面的Admin,AdminRole,AdminAuthorize是三个实体,也即需要建的三个表名。

四、实体类的构建

首先引用:

using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;

  其中可以自定义表名,用[Table("tablename")],如果不设置则,表名默认为实体类名,每个表必须用[key]指定表的主键字段,不然在构建migration的时候会报错。同时如果有主外键关联的表,需要用虚拟泛型函数来处理,如在customer表中,有一个DialogRecord表,则在customer表中需要这么写:

public virtual ICollection<DialogRecord> dialogs  { get; set; }/ /对话消息 五、建表 利用Migration命令在nuget命令行中依次运行以下三个命令: (1)Enable-Migrations,构建migration模块,如果要重新构建,在代码中删除该模块重新输入该命令即可
  (2)Add-Migration init,初始化migration
  (3)Update-Database,建表 六、写入数据库 给数据库表添加数据,这里举例给Admin添加数据,命令如下: var db = new AppDb();   db.Admin.Add(data);//data必须是Admin的对象   db.SaveChanges();//保存数据 执行sql语句:db.Database.SqlQuery<XY_Hospital>("select * from XY_Hospital").ToList()

通过以上六步就完成了整个过程,包括建表,写入数据库操作,非常简单快捷,当然增删改查也可以,这里只写了写入操作。

 

转载于:https://www.cnblogs.com/marso/p/8638493.html

总结

以上是生活随笔为你收集整理的EF使用笔记的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。