EF的Code First是一个比较强大也比较有用的功能,他可以让你先写代码,最后根据代码去生成数据库,非常符合OO设计的要求,抛开数据库层面不管(当然不是完全的不管),只管对象的设计。

首先,说一下我做测试的环境:EF 6.0/PostgreSql 9.2

第一步:添加程序对EF的引用,有个偷懒的办法是,添加一个空的Code Fist ADO.NET实体数据模型,这样,VS会自动帮你添加对EF以及相关的DLL的引用

第二步:用Nuget添加对Npgsql For Entity Freamwork的引用,这样子的话,Nuget会自动帮你添加NpgSql和NpgSql.EntityFreamWork的引用,并且会对你的Config文件中添加配置。

2016年3月21日更新:先通过Nuget添加对EntityFramework6.Npgsql的引用

第三步:配置Config文件

 <?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</configSections>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
</startup>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
<parameters>
<parameter value="v11.0" />
</parameters>
</defaultConnectionFactory>
<providers>
<provider invariantName="Npgsql" type="Npgsql.NpgsqlServices, Npgsql.EntityFramework" />
</providers>
</entityFramework>
<system.data>
<DbProviderFactories>
<remove invariant="Npgsql"/>
<add name="Npgsql Data Provider" invariant="Npgsql" description=".Net Data Provider for PostgreSQL" type="Npgsql.NpgsqlFactory, Npgsql, Version=2.2.3.0, Culture=neutral, PublicKeyToken=5d8b90d52f46fda7" support="FF" />
</DbProviderFactories>
</system.data>
<connectionStrings>
<add name="ConnectionStr" connectionString="server=127.0.0.1;port=5432;Database=test;uid=*****;pwd=*****" providerName="Npgsql" />
</connectionStrings>
</configuration>

Config

在这个过程中,我对几个地方有了比较清楚的认识:

1.<add name="ConnectionStr" connectionString="server=127.0.0.1;port=5432;Database=test;uid=postgres;pwd=baixu963." providerName="Npgsql" /> 在这句里面,ProviderName要填写的就是访问数据库的ADO.NET命名空间,比如Sqlserver就是System.Data.SqlClient,MySql就应该是:MySql.Data.MySqlClient,.net访问PostgreSql是由开源项目Npgsql提供的驱动程序,命名空间也是NpgSql,所以,这里的providerName="Npgsql"。

2.在WebConfig中,configSections节点一定要在第一个,不要乱改动他的位置。

3.DbProviderFactories节点:中文含义:数据库供应商工厂,这也是为.net访问数据库提供的一个配置,因为这是微软搞出来的,他对SqlServer的支持,都已经给过默认值了,所以我们平时配置Sqlserver的时候不需要管,但是配置别的一些数据库,那就需要修改了。其中,最重要的就是invariant这个东西了,这个对应的也是数据库的ADO.NET驱动的命名空间。还有Type也需要注意,下面再给出MySql的写法:

 <DbProviderFactories>
<add name="MySQL Data Provider"
invariant="MySql.Data.MySqlClient"
description=".Net Framework Data Provider for MySQL"
type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data, Version=5.2.5.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"/>
</DbProviderFactories>

MySql DbProviderFactories

配置文件就到这里吧,下面开始代码的部分。

首先,给出一个Person类:

  public class Person
{
[Key]
public int Id { get; set; }
[StringLength()]
public string Name { get; set; }
}

Person

Id上面的特性标签Key代表这是一个主键,Name上面的StringLength是告诉数据库,这个字段是32个长度。

然后,新建一个DbContext(如果你刚才是通过新建空的Code Fist ADO.NET实体数据模型引用的EF,他会自动帮你建一个Demo出来,你可以直接改那个),不多解释了,直接上代码,

public class EfDbContext : DbContext
{
public EfDbContext()
: base("name=ConnectionStr")
{

}
public virtual DbSet<Person> Person { get; set; }
}

其中Name对应的值是数据库中的连接字符串所对应的Name,然后下面的DbSet<T>就对应着数据库中的一个表,注意这个DbSet一定要是Virtual,EF需要去重写它。

基本的咱们已经写完了,咱们来试试,我这是控制台程序,所以直接是控制台的代码啦,你们随意。

 class Program
{
static void Main(string[] args)
{
EfDbContext context=new EfDbContext();
Person person=new Person();
person.Name = "baiyunchen";
context.Person.Add(person);
context.SaveChanges();
var p = context.Person.FirstOrDefault(x => x.Name == "baiyunchen") ?? new Person();
Console.WriteLine(p.Name);
Console.ReadKey();
}
}

Test Code

等待他输出了P的名字之后,再去看数据库,他已经帮忙自动建库,建表,插入数据,一切OK了。

比较奇怪的是,他新建了个People表,后面我强制给Person类加了[Table="Person"]这样才给我建了Person表,不知道是不是跟哪个关键字冲突了。

另外,我发现,EF在你实体变动了之后,你如果需要处理,会变得异常的麻烦。先写到这里,我得继续研究研究EF了。

最新文章

  1. Find和FirstOrDefault()有什么区别?
  2. js javascript jquery区别和联系
  3. python dict
  4. 整合ssh model $$_javassist_13 cannot be cast to javassist.util.proxy.Proxy
  5. html中table的画法及table和div的区别
  6. CocoStudio基础教程(1)创建UI并载入到程序中
  7. SpringTest 使用说明 -构建无污染纯绿色事务测试框架 (记录用)
  8. Balanced Binary Tree(Java代码没有结束,是什么原因???)
  9. monkey源码分析之事件注入方法变化
  10. 洛谷P2319 [HNOI2006]超级英雄
  11. BZOJ_4517_[Sdoi2016]排列计数_组合数学
  12. java文件与流课后作业
  13. Android绘制优化(一)绘制性能分析
  14. 【转】微信小程序开发之图片等比例缩放 获取屏幕尺寸图片尺寸 自适应
  15. golang反射举例
  16. SpringMvc中获取Request
  17. python之 列表常用方法
  18. 在自己的服务器上部署 GitLab 社区版
  19. Java之关于JSTL引入问题
  20. 001servlet的基本知识

热门文章

  1. SQL2008使用with求余额表,流水账方式
  2. browserslist 目标浏览器配置表
  3. SQL COUNT DISTINCT
  4. java压缩与解压
  5. 360浏览器内核控制标签meta说明
  6. 目前比较全的CSS重设(reset)方法总结(转)
  7. 实验一:使用符号执行工具klee对软件进行破解(来自于klee官网)
  8. CCF201412-1 门禁系统
  9. 【NLP_Stanford课堂】文本分类2
  10. .Net中初探Redis