EFCodeFirst 数据库连接

EFCodeFirst
数据库连接

1.NuGet安装实体命令

  1. PM> Install-Package EntityFramework 

2.数据库连接字符串

自动添加得app.Config大体如下:

  1. <?xml version="1.0" encoding="utf-8"?> 

  2. <configuration> 

  3. <configSections> 

  4. <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=4.4.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" /> 

  5. </configSections> 

  6. <entityFramework> 

  7. <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework"> 

  8. <parameters> 

  9. <parameter value="Data Source=(local); Database=Portal; User ID=sa; Password=; MultipleActiveResultSets=True" /> 

  10. </parameters> 

  11. </defaultConnectionFactory> 

  12. </entityFramework> 

  13. </configuration> 

设置DefaultConnectionFactory之后,使用Entity Framework连接数据库不需再在其他地方进行设置,Entity Framework也不需要指定数据库连接。

通过配置connectionStrings

  1. <?xml version="1.0" encoding="utf-8"?> 

  2. <configuration> 

  3. <connectionStrings> 

  4. <add name="PortalContext" connectionString="Data Source=(local); Database=Portal; User ID=sa; Password=; MultipleActiveResultSets=True" 

  5. providerName="System.Data.SqlClient" /> 

  6. </connectionStrings> 

  7. </configuration> 

3.DbContext连接数据库

  1. using System; 

  2. using System.Collections.Generic; 

  3. using System.Linq; 

  4. using System.Text; 


  5. using System.Data.Entity; 


  6. namespace Portal 



  7. public class PortalContext : DbContext 



  8. static PortalContext() 



  9. Database.SetInitializer<PortalContext>(null); 

  10. //Database.SetInitializer(new CreateDatabaseIfNotExists<PortalContext>()); 

  11. //Database.SetInitializer(new DropCreateDatabaseAlways<PortalContext>()); 

  12. //Database.SetInitializer(new DropCreateDatabaseIfModelChanges<PortalContext>()); 




  13. public PortalContext() 

  14. : base("name=PortalContext") 






  15. protected override void OnModelCreating(DbModelBuilder modelBuilder) 









静态构造函数中设置数据库的初始化方式,在构造函数中指定App.config的connectionString。

3种初始化方式

  • CreateDatabaseIfNotExists。默认,数据库不存在创建数据库。
  • DropCreateDatabaseWhenModelChanges。数据模型发生改变的时候,先删除,后创建。
  • DropCreateDatabaseAlways。总是先删除后创建,无论模型是否变化。
  • Database.SetInitializer<PortalContext>(null); 关闭初始化功能。

4.基本常用设置

  • 禁用延迟加载(Lazy Loading)
  • 禁用关系数据的级联删除
  • 禁用默认表名复数形式
  1. // 禁用延迟加载 DbContext类中设置 

  2. this.Configuration.LazyLoadingEnabled = false; 

  3. // 禁用一对多级联删除 OnModelCreating方法中设置 

  4. modelBuilder.Conventions.Remove<OneToManyCascadeDeleteConvention>(); 

  5. // 禁用多对多级联删除 OnModelCreating方法中设置 

  6. modelBuilder.Conventions.Remove<ManyToManyCascadeDeleteConvention>(); 

  7. // 禁用默认表名复数形式 OnModelCreating方法中设置 

  8. modelBuilder.Conventions.Remove<PluralizingTableNameConvention>(); 

EFCodeFirst 数据库连接的更多相关文章

  1. EF--Codefirst 加密数据库连接字符串

    http://www.tuicool.com/articles/QvYbEn 一.EF,CodeFirst加密SQL连接符 public LifeHelpContext() : base(" ...

  2. Java数据库连接技术——JDBC

    大家好,今天我们学习了Java如何连接数据库.之前学过.net语言的数据库操作,感觉就是一通百通,大同小异. JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力. JDBC API ...

  3. .NET跨平台之旅:数据库连接字符串写法引发的问题

    最近在一个ASP.NET Core站点中遇到一个奇怪问题.当用dotnet run命令启动站点后,开始的一段时间请求执行速度超慢,有时要超过20秒,有时甚至超过1分钟,日志中会记录这样的错误: Sys ...

  4. Entity Framework 6 Recipes 2nd Edition(12-3)译 -> 数据库连接日志

    12-3. 数据库连接日志 问题 你想为每次与数据库的连接和断开记录日志 解决方案 EF为DbContext的连接公开了一个StateChange 事件.我们需要处理这个事件, 为每次与数据库的连接和 ...

  5. 如何修复VUM在客户端启用之后报数据库连接失败的问题

    在上一篇随笔中介绍了关于重新注册VMware Update Manager(VUM)至vCenter Server中的方法,最近有朋友反应,原本切换过去好好的更新服务为什么某次使用一下就不灵了? 当时 ...

  6. JDBC_part1_Oracle数据库连接JDBC以及查询语句

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! JDBC part1 JDBC概述 jdbc是一种用于 ...

  7. tornado+sqlalchemy+celery,数据库连接消耗在哪里

    随着公司业务的发展,网站的日活数也逐渐增多,以前只需要考虑将所需要的功能实现就行了,当日活越来越大的时候,就需要考虑对服务器的资源使用消耗情况有一个清楚的认知.     最近老是发现数据库的连接数如果 ...

  8. Java第三方数据库连接池库-DBCP-C3P0-Tomcat内置连接池

    连接池原理 数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”.预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去.我们可以通过设定连接池 ...

  9. Java-加载数据库驱动,取得数据库连接

    在Java中想要进行数据库操作,最重要的两个步骤就是加载数据驱动,然后取得数据库连接. 1.加载 数据库驱动( Class.forName(String className) ): 因为Java是一种 ...

随机推荐

  1. Codeforces Round #681 (Div. 2, based on VK Cup 2019-2020 - Final)【ABCDF】

    比赛链接:https://codeforces.com/contest/1443 A. Kids Seating 题意 构造一个大小为 \(n\) 的数组使得任意两个数既不互质也不相互整除,要求所有数 ...

  2. Codeforces Round #657 (Div. 2) B. Dubious Cyrpto(数论)

    题目链接:https://codeforces.com/contest/1379/problem/B 题意 给出三个正整数 $l,r,m$,判断在区间 $[l,r]$ 内是否有 $a,b,c$ 满足存 ...

  3. Codeforces Round #547 (Div. 3) F1/2. Same Sum Blocks (Easy/Hard) (贪心,模拟)

    题意:有一长度为\(n\)的数组,求最多的区间和相同的不相交的区间的个数. 题解:我们可以先求一个前缀和,然后第一层循环遍历区间的右端点,第二层循环枚举左端点,用前缀和来\(O(1)\)求出区间和,\ ...

  4. nuoyanli 520 Let‘s play computer game

    H题 描述 xxxxxxxxx在疫情期间迷上了一款游戏,这个游戏一共有nnn个地点(编号为1--n1--n1--n),他每次从一个地点移动到另外一个地点需要消耗 一定的能量,每一个地点都有一些珠宝,输 ...

  5. EFCore学习记录--数据访问技术人门

    1.安装Microsoft.EntityFrameworkCore.Sqlite.Microsoft.EntityFrameworkCore.Tools包2.创建模型 数据库上下文模型:Bloggin ...

  6. 11.PowerShell DSC之安装PowerShell Module

    打开https://powershellgallery.com,检索你需要的目标模块,我们以安装名为"xmysql"的module为例: 自动安装 1.执行命令install-mo ...

  7. 四、Jmeter 集合点(实际场景应用)

    一.jmeter集合点的作用域及作用范围 先明确一些概念:1)定时器是在每个sampler(采样器)之前执行的,而不是之后: 是的,你没有看错,不管这个定时器的位置放在sampler之后,还是之下,它 ...

  8. SpringCloud @RefreshScope标注的Bean在生命周期中怎么样的?

    @RefreshScope 前言 该文章是由上一篇引申而来的,上一篇文章描述了Nacos是怎么触发配置刷新的,接着来写有关@RefreshScope的一些东西,都是由DEBUG而来 上一篇 文章概览 ...

  9. 爬虫入门四 re

    title: 爬虫入门四 re date: 2020-03-14 16:49:00 categories: python tags: crawler 正则表达式与re库 1 正则表达式简介 编译原理学 ...

  10. 秋招C++面试相关总结索引

    C++相关 C++ part1 C++ part2 C++ part3 C++ part4 C++ part5 C++ part6 C++ part6.5 C++ part7 C++ part8 C+ ...