C# EntityFramework简单入门

本文旨在通过一个小练习,对EntityFramework的Code First模式有一个简单的感性认识。

环境:VS2013,SQL Server 2012

打开“SQL Server Management Studio”。

对象资源管理器中|数据库|右键|新建数据库,输入数据库名“BookShop”,确定。

对象资源管理器中|数据库|BookShop|新建查询,在打开的新窗口中输入:

CREATE TABLE Books
(
    [ID] INT NOT NULL PRIMARY KEY IDENTITY,
    [Title] NVARCHAR(100) NOT NULL,
    [Author] NVARCHAR(50) NOT NULL,
    [Price] DECIMAL(16, 2) NOT NULL
)
INSERT INTO Books ([Title], [Author], [Price]) VALUES(‘Winform编程入门‘, ‘张三‘, 34.50)
INSERT INTO Books ([Title], [Author], [Price]) VALUES(‘ASP.NET MVC编程入门‘, ‘李四‘, 32.10)
INSERT INTO Books ([Title], [Author], [Price]) VALUES(‘资治通鉴‘, ‘司马光‘, 88.50)
INSERT INTO Books ([Title], [Author], [Price]) VALUES(‘史记‘, ‘司马迁‘, 132.10)
INSERT INTO Books ([Title], [Author], [Price]) VALUES(‘西游记‘, ‘吴承恩‘, 28.50)
INSERT INTO Books ([Title], [Author], [Price]) VALUES(‘红楼梦‘, ‘曹雪芹‘, 132.10)

点击工具栏中的执行,Books表和初始数据就建立好了。

打开VS2013,新建一个控制台应用程序。

项目|右键|管理NuGet程序包,在打开的对话框中,左边选择联机,右上角的搜索里输入“EntityFramework”,找到后点击安装,完成后会在解决方案目录下多一个“packages”目录。

在App.config中添加连接字串:

  <connectionStrings>
    <add name="DbBookContext" connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=BookShop;User ID=sa;Password=***" providerName="System.Data.SqlClient" />
  </connectionStrings>

在Program.cs中添加对应的代码:

    public class Book
    {
        public int ID { get; set; }
        public string Title { get; set; }
        public string Author { get; set; }
        public decimal Price { get; set; }
    }
    public class DbBookContext : DbContext
    {
        //public DbBookContext()
        //{
        //    Database.Connection.ConnectionString = @"Data Source=.\SQLEXPRESS;Initial Catalog=BookShop;User ID=sa;Password=server01";
        //}
        public DbSet<Book> Books { get; set; }
    }
    class Program
    {
        static void Main(string[] args)
        {
            DbBookContext bookContext = new DbBookContext();
            IQueryable<Book> books = bookContext.Books;
            foreach (Book book in books.OrderBy(b=>b.Price))
            {
                Console.WriteLine(String.Format("{0},{1},{2},{3}", book.ID, book.Title, book.Author, book.Price));
            }
        }
    }

生成并运行。(连接字串也可以在DbBookContext的构造函数中赋值。)

试验一:将DbBookContext改成其他名字,找不到连接字串,运行不报错,也没有结果,数据库里生成了一个新的数据库。

实验二:将Book中的ID改名,报异常:EntityType ‘Book‘ has no key defined.

实验三:将Book改成Book1,运行不报错,运行后数据库里多了两个空表:Book1,__MigrationHistory,此时再把代码改回去,运行会报异常,在数据库里删除__MigrationHistory就好了。

实验四:将DbBookContext的Books字段改成别的名字,运行结果正常,这个名字随便起。

初步结论,数据库表名是类名的复数形式,试了一下Foot,生成的表名是Feet,如果不是正常的单词,就直接加个“s”。

时间: 2024-10-24 22:21:44

C# EntityFramework简单入门的相关文章

Asp.Net EF Code First 简单入门

今天在上班期间花了点时间学习了一下微软的EntityFramework Code First技术,这篇文章只是简单的入门,不多废话,下面直入主题. 一.首先添加一个解决方案,接着添加一个web网站,DataAccess类库(用于数据访问),Model类库(实体层),结构如下: 二.安装EntityFramework.通过Nuget Package Manager进行安装(如果还没有安装Nuget的,可以通过tools-extension manager进行安装),在tools-Nuget Pac

正则表达式简单入门

 正则表达式简单入门    正则表达式在平常编程中有着大量的应用,对于任何一个想学习编程的人来说,正则表达式是一个必须掌握的知识. 废话不多说,下面先对正则表达式做一个简单的入门介绍,在后续的文章中,将会进行详细的介绍.    一.元字符 元字符一共有12个:$ ( ) [ { ? + * . ^ \ | 元字符有特殊的含义,如果要使用其字面值,则必须对其进行转义. 如: \$  \*  \( 等等 二.控制字符或不可打印字符 \a  警报 \e  退出 \f  换页 \n  换行 \r 

程序员,一起玩转GitHub版本控制,超简单入门教程 干货2

本GitHub教程旨在能够帮助大家快速入门学习使用GitHub,进行版本控制.帮助大家摆脱命令行工具,简单快速的使用GitHub. 做全栈攻城狮-写代码也要读书,爱全栈,更爱生活. 更多原创教程请关注头条号.每日更新.也可以添加小编微信:fullstackCourse.一起交流,获取最新全栈教程信息.因为FQ原因,不能下载客户端的同仁,可以关注后回复“GitHub客户端”获取安装软件. 上篇教程:GitHub这么火,程序员你不学学吗? 超简单入门教程 干货 GitHub概念部分出现了一丝纰漏.为

iBatis简单入门教程

iBatis 简介: iBatis 是apache 的一个开源项目,一个O/R Mapping 解决方案,iBatis 最大的特点就是小巧,上手很快.如果不需要太多复杂的功能,iBatis 是能够满足你的要求又足够灵活的最简单的解决方案,现在的iBatis 已经改名为Mybatis 了. 官网为:http://www.mybatis.org/ 搭建iBatis 开发环境: 1 .导入相关的jar 包,ibatis-2.3.0.677.jar .mysql-connector-java-5.1.6

Asp.Net MVC学习总结(一)——Asp.Net MVC简单入门

出处:http://www.cnblogs.com/SeeYouBug/p/6401737.html 一.MVC简单入门 1.1.MVC概念 视图(View) 代表用户交互界面,对于Web应用来说,可以概括为HTML界面,但有可能为XHTML.XML和Applet. 模型(Model) 表示用户对其数据的操作的一个封转.可以分为视图模型(view model)和领域模型(domain models),视图模型就是在视图与控制器之间传输数据的一个封转,而领域模型就是业务逻辑,后台数据模型等的一个集

Java日志系统---Logger之简单入门

Java 中自带的日志系统,今天抽空了解了一点,算是入了门,所以将自己的一些心得记录下来,以备日后查看,有兴趣的朋友,看到此文章,觉得有错误或需要添加的地方,请在下方评论留言,大家可以共同进步,谢谢:) Java中关于日志系统的API,在 java.util.logging 包中,在这个包中,Logger类很重要. Logger类是用来记录 某个级别的日志消息: 级别共分为以下几类,从上倒下,级别依次下降: SEVERE(严重)------级别最高 WARNING(警告) INFO CONFIG

响应式网页设计简单入门(强烈推薦!!!!)

响应式网页设计简单入门 Overview: 构造基本的HTML页面 动态加载样式表 Viewport 字体缩放 侧边栏 导航菜单 图片自适应 其他 总结 说到响应式网页设计(Responsive web design),最近在谷歌加上碰到个奇葩贴子,通过一个原始到无法再简单的网页Motherfucking Website及满屏幕的fuck道出了网页设计的真谛,这孩子不是个激进分子就是个报复社会型的货没错,虽然整篇文章就像是泼妇骂街,但我特么是笑着读完的.. 统计了下全文共用Fuck (包括fuc

Android HttpGet() 请求简单入门实例

HttpClient httpclient = new DefaultHttpClient(); String url = "http://example.com"; List<NameValuePair> params = new ArrayList<NameValuePair>(); params.add( new BasicNameValuePair( "param", "value" ) ); URI uri =

delphi指针简单入门

delphi指针简单入门:         看一个指针用法的例子:     1         var     2             X,   Y:   Integer;       //   X   and   Y   整数类型     3             P:   ^Integer;           //   P   指向整数类型的指针     4         begin     5             X   :=17; //   给   X   赋值     6