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
总结
- 上一篇: 装饰器带参数
- 下一篇: 简单实现一边固定,另一边自适用