zoukankan      html  css  js  c++  java
  • 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()

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

  • 相关阅读:
    springboot 打包部署
    mybatis 插入空值时报错 TypeException
    margin 居中
    node.js 开发命令行工具 发布npm包
    webstorm vue环境设置
    vue数组操作不触发前端重新渲染
    数字英文超过宽度不换行问题
    Jquery checkbox 遍历
    小图标垂直居中
    vue this.$router.push 页面不刷新
  • 原文地址:https://www.cnblogs.com/marso/p/8638493.html
Copyright © 2011-2022 走看看