• 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()

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

  • 相关阅读:
    js里的稀疏数组
    JS中二进制与十进制的相互转换
    【leetcode-03】给定一个字符串,请你找出其中不含有重复字符的最长子串的长度
    JavaScipt30(第二十二个案例)(主要知识点:getBoundingClientRect)
    JavaScipt30(第十八个案例)(主要知识点:Array.prototype.map)
    JavaScipt30(第十个案例)(主要知识点:选中一个数组中间相连部分进行操作的一种思路)
    JavaScipt30(第八个案例)(主要知识点:canvas)
    Lydsy2017省队十连测
    几个多项式的题
    poj3294Life Forms
  • 原文地址:https://www.cnblogs.com/marso/p/8638493.html
Copyright © 2020-2023  润新知