的1些体会,创造实体框架数据模型

真以为温馨的知识面依然相比窄,此前,居然还不知晓SqlLocalDb。

Contoso University  Web 应用程序

您会在那一个科目中创设的应用程序是二个简易的大学网址。

用户能够查看和翻新学生、
课程和教授消息。那里有多少个荧屏,您将成立。

美高梅开户网址 1 

美高梅开户网址 2

其一网址的用户界面样式一向看似由放手的模版,生成的始末,以便本课程能够集中首要精力怎么着采用实体框架。

话外篇:

       
在本篇小说中,咱们上学怎么使用实体框架的“Code First Migrations ”(也号称代码先行效用)工具,使用个中的“迁移”成效对模型类实行1些修改,同时1起创新对应数据库的表结构。

SqlLocalDb是啥?其实正是简化SQL Server的本土数据库,能够那样子说,SQL
Server既能够作为长途,也能够做地点,

系统必备组件

大势和显示器截图在本教程中一经你正在选拔Visual Studio
2012或Visual
Studio 贰零一一速成网址,最新的更新与结束20一3 年 7 月,安装的 Windows Azure SDK。你可以获取这1切与下部的链接:

Windows Azure SDK 以 Visual Studio
2012

借使你有安装了 Visual
Studio,上边的链接将设置任何缺少的机件。如若你从未 Visual Studio,该链接将设置 Visual Studio 2011速成网址。您能够行使 Visual Studio 20壹3年,但一些所需的先后和显示器会有所分歧。

     
 由于觉得温馨的机械相比较慢,配置不佳,所以近来想把在此以前的类型布局到实验室的服务器上,不过出于常不在实验室,所以在想能否长途陈设。由此明日专门商讨了一晃具体的长河,上面和豪门分享一下。本身新手,还望大虾勿喷,有怎么着问题,还望高手辅导。

       
暗中同意景况下,当您使用实体框架的“Code First Migrations ”工具,实体框架会自行创造三个数据库。“代码先行功用”首先会添加一个新表到数据库中,以便跟踪数据库的架构是还是不是与模型类同步。假使它们分裂台,实体框架会抛出2个错误。这样开发人士在支付时就能更易于地追查难题出在怎么地点,而其他的开发格局就不得不在运作时通过模糊的错误新闻查找什么地点出错了。 

而SqlLocalDb只好同日而语本地使用。说的直接一点,SqlLocalDb正是叁个轻量级的根据本地的T-SQL数据库,全称:SQL
Server Express LocalDb。

成立 MVC Web 应用程序

开拓 Visual Studio 并创办二个新 C#
项目命名称叫”ContosoUniversity”使用ASP.NET MVC 4 Web
应用程序
模板。请确认保证您的靶子.NET 框架
4.5
 (你会使用enum的属性,并且,需要.NET
4.5)。

美高梅开户网址 3

新的 ASP.NET MVC 4 项目对话框中甄选的互连网应用模板。

Razor视图引擎接纳,和创设叁个单元测试项目的1些体会,创造实体框架数据模型。的复选框处于清除状态的假期。

单击确定.

美高梅开户网址 4

1、本文实验环境:

1、设置代码优先迁移的模子更改 

         若是您使用的是Visual Studio 二〇一三,从消除方案能源管理器中双击Test.mdf文件,会打开数据库管理工科具。当中Visual Studio Express For Web版本的VS将呈现数据库财富管理器,Visual Studio 二〇一二别样版本会彰显服务器财富管理器。如若你使用的是Visual Studio 20第10中学,使用SQL Server对象财富管理器。 
         一)在服务器财富管理器中—》“数据连接”中(数据库管理工科具、数据库浏览器、服务器能源管理器或SQL Server对象资源管理器),右键单击developer\sqlexpress.Test.dbo,然后选拔删除。如下图一、图2。图壹是去除连接,图二是删除数据库。

 美高梅开户网址 5

 图1

 

 美高梅开户网址 6

图2

      二)执行菜单–》工具–》生成–》生成化解方案,以保险没错误。 
       三)从菜系–》工具菜单中,单击库程序包管理器–》程序包管理器控制台。如下图。

 美高梅开户网址 7

 

            四)在Visual Studio的花花世界窗体中的“程序包管理器控制台”窗口的“>”提醒符下输入“Enable-Migrations -ContextTypeName MvcApplication1.Models.BookDBContext”。如下图。

 美高梅开户网址 8

         
五)在进行完Enable-Migrations命令之后(如上海教室所示),会在项目中开创叁个新的文本夹“Migrations”, 在那个文件夹中创立三个Configuration.cs文件。如下图。

 美高梅开户网址 9

           陆)在Visual Studio中开拓Configuration.cs文件。用上面的代码替换Configuration.cs文件的Send方法:

 

namespace MvcApplication1.Migrations

{

    using System;

    using System.Data.Entity;

    using System.Data.Entity.Migrations;

    using System.Linq;

    using MvcApplication1.Models;



    internal sealed class Configuration : DbMigrationsConfiguration<MvcApplication1.Models.BookDBContext>

    {

        public Configuration()

        {

            AutomaticMigrationsEnabled = false;

        }



        protected override void Seed(MvcApplication1.Models.BookDBContext context)

        {

            //  This method will be called after migrating to the latest version.



            //  You can use the DbSet<T>.AddOrUpdate() helper extension method 

            //  to avoid creating duplicate seed data. E.g.

            //

            //    context.People.AddOrUpdate(

            //      p => p.FullName,

            //      new Person { FullName = "Andrew Peters" },

            //      new Person { FullName = "Brice Lambson" },

            //      new Person { FullName = "Rowan Miller" }

            //    );

            //

            context.Books.AddOrUpdate(i => i.BookID,

        new Book

        {

            Name = "When Harry Met Sally",

            PublishDate = DateTime.Parse("1989-1-11"),

            Category = "MS",

            AuthorID=1,

            Numberofcopies=12,

            Price = 7.99M


        },


         new Book

         {

             Name = "Ghostbusters ",

             PublishDate = DateTime.Parse("1984-3-13"),

              Category = "MS",

            AuthorID=1,

            Numberofcopies=112,

             Price = 8.99M

         },

         new Book

         {

             Name = "DB 2",

             PublishDate = DateTime.Parse("1986-2-23"),

               Category = "IBM",

            AuthorID=1,

            Numberofcopies=22,

             Price = 9.99M,

         }

   );
        }

    }

}

 

           七)使用鼠标右键单击Book下的革命波浪线,在弹出菜单中选择“解析”菜单项,然后在弹出菜单中选用“MvcApplication一.Models”;如下图。

 美高梅开户网址 10

在通过如此做了后头,Visual Studio会自动在代码中加进using语句如下:

 

using MvcApplication1.Models;

美高梅开户网址, 

 

       
在“程序包管理器控制台”窗口中施行了“Code First Migrations ”功效中的“迁移”命名之后,代码会自动调用Send 方法(即程序包管理器控制台会调用此办法立异数据库中的数据),并且实施该措施时只要代码中的对象数据不设有则插入,如果存在则开始展览翻新。 

二、迁移数据库
       壹) 如若此时在Visual Studio中按Ctrl-Shift-B(或许菜单–>生成–>生成消除方案)来编译项目,将会并发编写翻译不了的谬误。如下图。 
       二) 接下来要树立一个DbMigration类来开始展览初叶迁移。使用那一个迁移命名创设几个新的数据库,那正是怎么作者在上一步中删除了Test.mdf文件。 
      
3) 在程序包管理器控制台窗口中,输入指令“dd-migration Initial”创建起来迁移。当中“Initial”的命名是随机的,是用来定名新创制的动员搬迁文件。如下图。

 美高梅开户网址 11

 

          
肆)“Code First Migrations ”功效中的“迁移”命名会在搬迁文件夹中的创建3个新的类公事(名字为{DATESTAMP}_Initial.cs),而且以此类中早已包蕴了创办数据库架构的代码。迁移文件名的命名规则中有贰个一定的时刻戳,用以帮助排序。检查{DATESTAMP}_Initial.cs文件,它包罗了创办Books表的数据库的印证。那么些{DATESTAMP}_Initial.cs文件将运转并创办数据库框架结构。然后运转Send方法为数据库填充测试数据。 
          
伍) 在先后包管理器控制台,输入指令“update-database”来创设数据库,并施行Send方法。如下图一,图2。

 美高梅开户网址 12

 图1

美高梅开户网址 13

 

图2

 

      
假使您获取八个谬误,提示表已经存在,不可能被创制,它恐怕是因为你正在周转应用程序,在您剔除了数据库之后,执行更新数据库以前。(如上海教室一)。

      在这种情况下,再度删除Test.mdf文件,然后重试“update-database”命令。如上海教室二。要是还是出现谬误,请删除该公文夹和内容,然后开始在那几个页面包车型大巴顶部(也正是删除Test.mdf文件然后开始展览启用,迁移)的求证。 
          6) 按F5周转应用程序,在浏览器中浏览Books/Index网站。会议及展览示Send方法中填充到数据库中的数据。如下图。

 美高梅开户网址 14

 

好,废话不多说。

建立了该网址的风骨

多少个大致的变动将开办网址菜单、 布局和主页。

打开Views\Shared\_Layout.cshtml,然后用以下代码替换该文件的内容。卓绝呈现所做的更改。

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8" />
        <title>@ViewBag.Title - Contoso University</title>
        <link href="~/favicon.ico" rel="shortcut icon" type="image/x-icon" />
        <meta name="viewport" content="width=device-width" />
        @Styles.Render("~/Content/css")
        @Scripts.Render("~/bundles/modernizr")
    </head>
    <body>
        <header>
            <div class="content-wrapper">
                <div class="float-left">
                    <p class="site-title">@Html.ActionLink("Contoso University", "Index", "Home")</p>
                </div>
                <div class="float-right">
                    <section id="login">
                        @Html.Partial("_LoginPartial")
                    </section>
                    <nav>
                        <ul id="menu">
                            <li>@Html.ActionLink("Home", "Index", "Home")</li>
                            <li>@Html.ActionLink("About", "About", "Home")</li>
                            <li>@Html.ActionLink("Students", "Index", "Student")</li>
                            <li>@Html.ActionLink("Courses", "Index", "Course")</li>
                            <li>@Html.ActionLink("Instructors", "Index", "Instructor")</li>
                            <li>@Html.ActionLink("Departments", "Index", "Department")</li>
                        </ul>
                    </nav>
                </div>
            </div>
        </header>
        <div id="body">
            @RenderSection("featured", required: false)
            <section class="content-wrapper main-content clear-fix">
                @RenderBody()
            </section>
        </div>
        <footer>
            <div class="content-wrapper">
                <div class="float-left">
                    <p>&copy; @DateTime.Now.Year - Contoso University</p>
                </div>
            </div>
        </footer>

        @Scripts.Render("~/bundles/jquery")
        @RenderSection("scripts", required: false)
    </body>
</html>

那段代码实行以下改变:

  • “笔者的 ASP.NET MVC
    应用程序”和”您的徽标在此间”的模板实例替换为”Contoso University”。
  • 丰盛将选取在本教程后边的多少个操作环节。

Views\Home\Index.cshtml,用以下代码,以消除有关 ASP.NET 和 MVC
模板段落替换该文件的始末:

@{
    ViewBag.Title = "Home Page";
}
@section featured {
    <section class="featured">
        <div class="content-wrapper">
            <hgroup class="title">
                <h1>@ViewBag.Title.</h1>
                <h2>@ViewBag.Message</h2>
            </hgroup>
        </div>
    </section>
}

Controllers\HomeController.cs,将值更改为ViewBag.Message Index操作方法中为”欢迎来到
Contoso 大学 !”,如上面包车型客车言传身教所示:

public ActionResult Index()
{
    ViewBag.Message = "Welcome to Contoso University";

    return View();
}

按 CT库罗德L + F伍 以运维网址。你看到主页与主菜单。

美高梅开户网址 15

      Windows Server 2012 R2

先是,怎么设置那么些SqlLocalDb?

成立数据模型

接下去,您将创制实体类为 Contoso
University 中的应用。你将起来与以下多个实体:

美高梅开户网址 16

还有StudentEnrollment实体之间的三个一对多关系和CourseEnrollment实业之间是壹对多的关系。换句话说,学生能够在自由数量的教程,并自然能够有自由数量的学生参与了它。

在偏下壹些中,您将创建二个类,用于每一个那么些实体。

假定您尝试编写翻译该品种,在您成功全体这么些实体类的创立之前,你就会获取编写翻译器错误。

      SQL Server 2012 Express

一)倘若设置过Visual Studio 20一五、20一七,一般已经安装到了微型总结机里。

学员实体

美高梅开户网址 17

模型文件夹中,创造Student.cs和水保代码替换为以下代码:

using System;
using System.Collections.Generic;

namespace ContosoUniversity.Models
{
    public class Student
    {
        public int StudentID { get; set; }
        public string LastName { get; set; }
        public string FirstMidName { get; set; }
        public DateTime EnrollmentDate { get; set; }

        public virtual ICollection<Enrollment> Enrollments { get; set; }
    }
}

StudentID属性将成为此类对应的数额库表的主键列。暗许景况下,实体框架将表达是命名的ID类名ID作为主键的质量。

Enrollments脾气是多个导航属性。导航属性持有此实体相关的别的实体。在那种状态下,1个Student实体的Enrollments性格将保留全部的Enrollment实体的尤其Student实体相关的。换言之,要是某一给定的Student行在数据库中有多个有关的Enrollment
(包括在其StudentID的外键列中的这一个学生主键值的行),该Student实体Enrollments导航属性将含有那多个Enrollment实体。

导航属性凉日定义为virtual中,以便他们得以动用一些实体框架效率,如延期加载。(延迟加载将稍后解释,读取相关数据课程稍后在本体系中。

假若3个导航属性能够包容几个实体
(如多多或1个一对多涉及),其项目必须是一个列表条目可以被添加、
删除和换代,如ICollection.

     Visual Studio 2013

     那里以Visual Studio 2017为例,在Visual Studio
Installer中的单个组件页面中,能够见到该器件已经被安装(灰色框框部分):

挂号实体

美高梅开户网址 18

模型文件夹中,创立Enrollment.cs和水保代码替换为以下代码:

namespace ContosoUniversity.Models
{
    public enum Grade
    {
        A, B, C, D, F
    }

    public class Enrollment
    {
        public int EnrollmentID { get; set; }
        public int CourseID { get; set; }
        public int StudentID { get; set; }
        public Grade? Grade { get; set; }

        public virtual Course Course { get; set; }
        public virtual Student Student { get; set; }
    }
}

等级属性是枚举。问号后Grade项目注解提示Grade属性是可以为
null。为 null 的品位是不相同于零级 — — null
意味着等级不敢问津或从不被指派。

StudentID性格是2个外键,且相应的领航属性是StudentEnrollment实业是与一个Student实业相关联,所以该属性只可以容纳三个纯粹的Student实体
(不像Student.Enrollments导航属性你眼下所述,而数组能够存放多少个Enrollment实体)。

CourseID属性是贰个外键,且相应的导航属性CourseEnrollment实业是与2个Course实体相关联。

     项目为:ASP.NET MVC
5.0,使用的是LocalDB数据库

 
  美高梅开户网址 19

课程实体

美高梅开户网址 20

模型文件夹中,创立Course.cs,现有代码替换为以下代码:

using System.Collections.Generic;
using System.ComponentModel.DataAnnotations.Schema;

namespace ContosoUniversity.Models
{
    public class Course
    {
        [DatabaseGenerated(DatabaseGeneratedOption.None)]
        public int CourseID { get; set; }
        public string Title { get; set; }
        public int Credits { get; set; }

        public virtual ICollection<Enrollment> Enrollments { get; set; }
    }
}

Enrollments品质是三个导航属性。Course实体可以与人身自由数量的Enrollment实体。

作者们会说越多关于[DatabaseGenerated(DatabaseGeneratedOption.None)]在接下去的课程中的属性。基本上,此属性允许你为该课程而不是生成的数据库输入的主键。

贰、使用Web
Deploy远程安插的规格

二)大概到Visual Studio 2017安装包安装该器件:

创建Database Context

坐标给定的数据模型的实业框架作用的主类是数据库上下文类。通过从System.Data.Entity.DbContext.aspx)类派生来创设此类。在你的代码中您钦定数据模型中归纳哪些实体。您仍是能够自定义某个实体框架作为。在那一个连串中,类名称为SchoolContext.

创办三个文本夹命名DAL (为数据访问层)。在该文件夹中成立一个新的类公事,命名叫SchoolContext.cs,和现有的代码替换为以下代码:

using ContosoUniversity.Models;
using System.Data.Entity;
using System.Data.Entity.ModelConfiguration.Conventions;

namespace ContosoUniversity.DAL
{
    public class SchoolContext : DbContext
    {
        public DbSet<Student> Students { get; set; }
        public DbSet<Enrollment> Enrollments { get; set; }
        public DbSet<Course> Courses { get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
        }
    }
}

此代码创设2个DbSet.aspx)属性为各样实体集。在实体框架术语中,实体集普通对应于数据库表,和叁个实体对应于表中的1行。

OnModelCreating.aspx)方法中的modelBuilder.Conventions.Remove言辞能够防患表名称正在趋向多元化。如若您不那样做,所生成的表将命名称叫StudentsCoursesEnrollments。相反,表名称将是StudentCourse
Enrollment。表名称应当多数开发商不相同意。本学科使用的是单数情势,但根本的一点是你可以选拔哪个你更爱好通过包含或简捷上边那行代码的花样。

      Web
Deploy能够用来地方和远程铺排Web项目,使用Web
Deploy布署时有如下需求:

     64位:

SQL 服务器快递 LocalDB

LocalDB是三个轻量级版本
SQL Server 表示数据库引擎的按需运转和运转在用户格局下。LocalDB 运维的 SQL Server Express
使你能够选拔数据库的.mdf文本作为特种的实践形式。平常情状下,LocalDB 数据库文件保留在 web
项目标App_Data文本夹中。在 SQL Server
Express用户实例作用还使你能够采纳.mdf文本,但不引入应用用户实例的法力
;因而,LocalDB
被引入使用的.mdf文件。

一般说来 SQL Server Express 的并不用于生产的 web
应用程序。LocalDB 特别不推荐用于生产一个 web
应用程序因为它不设计工作的非官方入境者。

在 Visual Studio 2012及随后的本子中,暗许情状下,Visual Studio 安装 LocalDB。在 Visual Studio 2010 及更早版本中,在默许情状下,Visual
Studio ; 安装 SQL Server Express (无 LocalDB)您必须手动安装它,如若你使用的 Visual Studio 20十。

在本教程中您将运用
LocalDB,以便数据库能够储存在.mdf文件所在的App_Data文本夹中。打开根Web.config文本并到connectionStrings聚拢中,添加1个新的连年字符串,如下边包车型客车示范所示。(请确认保障您更新Web.config文本中的根项目文件夹。其余,还有 Web.config文本是您不供给更新的视图子文件夹中。)

 <add name="SchoolContext" connectionString="Data Source=(LocalDb)\v11.0;Initial Catalog=ContosoUniversity;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|\ContosoUniversity.mdf" providerName="System.Data.SqlClient" />

私下认可景况下,实体框架查找名字为DbContext
(此项目SchoolContext ) 相同的连天字符串。您曾经添加的连日字符串内定贰个名字为ContosoUniversity.mdf位于App_Data文件夹中的
LocalDB 数据库。更加多的音讯,请参见ASP.NET
Web 应用程序的 SQL
服务器连接字符串.

骨子里,您不必要钦点的接连字符串。假如您不提供连接字符串,实体框架将开创一个为你
;不过,数据库可能不可能在您的应用程序的App_data文本夹中。将创制数据库的新闻,请参见代码第三遍到新的数据库.

connectionStrings集合还持有叁个名称为DefaultConnection的用来成员身份数据库的总是字符串。在本教程中,您不会选取成员身份数据库。八个再而三字符串之间的绝无仅有差距是数据库名称和名称属性值。

       1.内需设置Web
Deploy ,上面地址:http://www.iis.net/downloads/microsoft/web-deploy

   
 美高梅开户网址 21

设置和实践代码第二回迁移

当你首先次起初支付应用程序时,您的数据模型更改频仍,而且每一遍得到与数据库不1起的模型更改。您能够配备实体框架能够自行删除并再度创建该数据库的每便变更数据模型。那不是一个题材在付出的最初,因为测试数据是很不难重新创建,可是你已经布置到生产后您平常想要更新数据库架构,而不删除数据库。迁移功能使代码第一要翻新数据库,而不会去除天公地道复创立它。早在开发周期中的三个新的连串你可能想要使用DropCreateDatabaseIfModelChanges.aspx) ,能够去除、
重新制造和另行设置为种子数据库每一回模型更改。一位,你准备布置您的应用程序,您能够变换为的迁徙方法。在本教程中,您将仅使用迁移。有关的详细音信,请参见代码第贰次迁移和搬迁截屏摄像连串.

 

    32位:

启用代码第3回迁移

  1. 工具菜单上,单击库程序包管理器,然后程序包管理器控制台.

    美高梅开户网址 22

  2. PM>提醒符下输入以下命令:

    enable-migrations -contexttypename SchoolContext
    

    美高梅开户网址 23

    此命令在 ContosoUniversity
    项目中,创设三个迁移文本夹和它在该文件夹中放贰个Configuration.cs文件,您能够编写配置迁移。

    美高梅开户网址 24

    Configuration类包蕴创建数据库时,每便换代数据模型更改后调用的Seed方法。

    internal sealed class Configuration : DbMigrationsConfiguration<ContosoUniversity.Models.SchoolContext>
    {
        public Configuration()
        {
            AutomaticMigrationsEnabled = false;
        }
    
        protected override void Seed(ContosoUniversity.Models.SchoolContext context)
        {
            //  This method will be called after migrating to the latest version.
    
            //  You can use the DbSet<T>.AddOrUpdate() helper extension method 
            //  to avoid creating duplicate seed data. E.g.
            //
            //    context.People.AddOrUpdate(
            //      p => p.FullName,
            //      new Person { FullName = "Andrew Peters" },
            //      new Person { FullName = "Brice Lambson" },
            //      new Person { FullName = "Rowan Miller" }
            //    );
            //
        }
    }
    

    Seed艺术的指标是使你能够向数据库中插入测试数据后代码第三次成立或更新它。

        二.设置Web Deploy之后,还供给启用IIS
的——管理服务,打开Windows
Server的服务器管理器,点击添加剧中人物和功能:

 
  美高梅开户网址 25

成立了种子法

种子.aspx)方法运转时期码第3次迁移成立数据库和每一回它将创新到新型的搬迁数据库。种子法的目标是为着使您能够将数据插入到表以前应用程序访问数据库第三次。

在早期版本的代码优先,迁移被假释在此以前,它是平凡的Seed方式来插入测试数据,因为在支付进程中的种种模型修改数据库不得不被全然除去和重新创建从零开端。与代码第贰回迁移,测试数据保存后数据库更改,由此包涵种子.aspx)方法中的测试数据1般不是必需。事实上,你不想要插入测试数据,假若你将使用迁移将数据库布署到生产,因为Seed情势将运维在生养中的Seed办法。在这种场所下你指望Seed艺术向数据库中插入你想要在生养中插入的数码。例如,您大概想要包含实际部门名称Department表中,当应用程序在生育中可用的数据库。

对此本课程,您将应用迁移的安插,但你的Seed措施将插入测试数据无论如何为了使它特别自在地查看应用程序的效益而无需手动插入大批量的数量的干活。

  1. Configuration.cs文件的始末替换为以下代码中,将测试数据加载到新的数据库。

    namespace ContosoUniversity.Migrations
    {
       using System;
       using System.Collections.Generic;
       using System.Data.Entity.Migrations;
       using System.Linq;
       using ContosoUniversity.Models;
    
       internal sealed class Configuration : DbMigrationsConfiguration<ContosoUniversity.DAL.SchoolContext>
       {
          public Configuration()
          {
             AutomaticMigrationsEnabled = false;
          }
    
          protected override void Seed(ContosoUniversity.DAL.SchoolContext context)
          {
             var students = new List<Student>
                {
                    new Student { FirstMidName = "Carson",   LastName = "Alexander", 
                        EnrollmentDate = DateTime.Parse("2010-09-01") },
                    new Student { FirstMidName = "Meredith", LastName = "Alonso",    
                        EnrollmentDate = DateTime.Parse("2012-09-01") },
                    new Student { FirstMidName = "Arturo",   LastName = "Anand",     
                        EnrollmentDate = DateTime.Parse("2013-09-01") },
                    new Student { FirstMidName = "Gytis",    LastName = "Barzdukas", 
                        EnrollmentDate = DateTime.Parse("2012-09-01"
    

        美高梅开户网址 26       

3)到SQL
Server下载宗旨下载SQL
Server
Express:

    之后点击下一步: 

下载之后,打开该引用,并点击“下载介质”:

       美高梅开户网址 27

美高梅开户网址 28

       美高梅开户网址 29

在弹出的页面中,选取LocalDB(第多少个),点击下一步下载SqlLocalDB.msi

       美高梅开户网址 30

美高梅开户网址 31

      在此地供给勾选“管理服务”,这一步相当关键。

注:SQL Server 2016 Express
LocalDB微软已经不再提供,近来为流行的,也正是上述的20一7本子。

      美高梅开户网址 32

四)百度网盘下载:

      之后下一步,等待完毕都部队署即可。完毕之后再服务列表中会多出Web
Management Service服务,并保障该服务运转。

美高梅开户网址 33

      美高梅开户网址 34

美高梅开户网址 35

    注意,要是该服务没有运转,可能未有启用“管理服务”效用,则在应用Web
Deploy陈设项目时会境遇如下错误:“未能连接到长途总计机,请确认保证在中远距离总括机上设置了
Web Deploy 并运维了所需的长河(“Web Management Service”)”:

听他们讲系统项目安装分歧的SqlLocalDB。

      美高梅开户网址 36

第二、连接SqlLocalDB

     
3.配置好管理服务之后,接下去须要进入IIS中通过管克制务来展开对应的设置:

一、打开Visual Studio
20壹7,依次点击“视图”(菜单栏)->“服务器财富管理器”,将会打开“服务器财富管理器”窗口:

      在我们启用管理服务后,进入IIS,会多出管理服务选项:

美高梅开户网址 37

      美高梅开户网址 38

2、右键点击“数据连接”,在弹出的上下文菜单中选取“添加连接”,在弹出的窗口旅长“服务器名”设置为(LocalDb)\MSSQLLocalDB,如下图所示:

     
双击管理服务,对IIS进行布署,那里自身保持了私下认可的安装,您能够依照自己的情景开始展览安装:

美高梅开户网址 39

     美高梅开户网址 40

然后附加3个名称叫MusicDBContext.mdf的数据库文件(文件能够友善定义)并点击显明,此时,MusicDBContext.数据库作为暗中同意的数据库,大家得以采用SQLLocalDB中的其余已有数据库。

     4.安插远布署Web项目标账户

变化的总是字符串如下:

   
基于安全着想,大家最佳提供单身的账户来布局Web项目,同时对于IIS中站点,能够钦赐哪些用户才有所布置应用程序到此站点的权杖。

Data Source=(LocalDb)\MSSQLLocalDB;AttachDbFilename=C:\Users\CNC\Desktop\MusicDBContext.mdf;Initial Catalog=MusicDBContext;Integrated Security=True

    首先点击”IIS 管理器用户”:

咱俩得以将mdf文件的门道改为相对路径:

    美高梅开户网址 41

Data Source=(LocalDb)\MSSQLLocalDB;AttachDbFilename=|DataDirectory|\MusicDBContext.mdf;Initial Catalog=MusicDBContext;Integrated Security=True

    然后点击”添加用户”:

其叁,编写程序对已有数据的读取

    美高梅开户网址 42

一般来说代码所示:

     然后安顿账户名和密码:

using System;
using System.Data;
using System.Data.SqlClient;
using System.Linq;

namespace ConsoleApp
{
    class Program
    {
        static void Main(string[] args)
        {
            string connectionString = @"Data Source=(LocalDb)\MSSQLLocalDB;Initial Catalog=MusicDBContext;Integrated Security=True";
            SqlConnection connection = new SqlConnection(connectionString);
            SqlDataAdapter adapter = new SqlDataAdapter("SELECT * FROM Musics",connection);
            DataTable table = new DataTable();
            adapter.Fill(table);
            var result = (from row 
                          in table.Rows.Cast<DataRow>()
                          select
                          new { ID = (int)row[0], Title = (string)row[1], ReleaseDate = (DateTime)row[2] });
            result.ToList().ForEach(x => Console.WriteLine($"{x.ID},{x.Title},{x.ReleaseDate}"));
        }
    }
}

   美高梅开户网址 43

运作结果如下:

   配置实现以后,接下去要求设置站点的用户权限。

美高梅开户网址 44

 
五.布局站点用户权限

 
注:MusicDBContext.mdf能够在百度网盘下载,地址:

  首先点击您程序将要公布到的站点,例如本文为Default Web
Site.之后在管制选用中点击”IIS 管理器权限”:

第陆、一些有关SqlLocalDB的参考资料

  美高梅开户网址 45

  之后点击“允许用户”:

 

 美高梅开户网址 46

 将在此以前大家抬高的iepi用户增加到选用的站点权限中:

 美高梅开户网址 47

最后点击明确,配置甘休。

 三、使用Visual Studio
201叁远道陈设项目

在颁发项目事先,我们需求对即将发表的站点(例如那里的
Default Web Site)根目录进香港行政局地权力配置。也正是”Local Service”账户供给有涂改站点目录的权杖。那里大家的“Default Web
Site”的目录对于着:

C:\inetpub\wwwroot,因而大家右键wwwroot文件件,选拔属性——安全——编辑,添加Local
瑟维斯账户,并勾选”修改“权限“

美高梅开户网址 48

 

若果未有实行以上的权位配置则会在公布的时候提醒不能在站点的物理目录下创办理文件件,未有开创权限。

在布局好站点的大体目录权限之后大家早先颁发web项目:

 

右键项目选用”发表”:

  美高梅开户网址 49

 

   然后新建三个布局文件,当然也足以接纳以前的,建议新建二个。

  美高梅开户网址 50

之后点击下一步,节奏配置 Web Deploy:

  美高梅开户网址 51

证实:服务器:输入IP地址即可

        站点名称:格式为”站点名称“/”应用程序名称”

        用户密码即为下面大家安顿的用户密码。

       
目的UXC90L:一般格式:

     
 之后点击验证,出现美高梅开户网址 52表示新闻无误,能够拓展揭橥了。接下来点击下一步,直到公布完毕,那里由于大家选择的是LocalDB,因而大家不用进行数据库配置。

四、配置LocalDb数据库

       LocalDB的是1个SQL Server Express轻量级版本的数据库引擎。
它在用户形式下运营、执行。LocalDB的运营在三个非正规的SQL Server
Express的实践形式,所以同意你使用MDF文件数据库。经常景况下,LocalDB的数据库文件都保存在web项指标App_Data文件夹下边。

      注意:在生养环境的Web应用程序中,大家不引入您使用SQL Server
Express。
尤其, LocalDB不应该被用于Web应用程序的生育条件,因为它设计之初不须要接纳IIS
然则,LocalDB的数据库能够很简单地搬迁​​到SQL Server或SQL
Azure中——摘自《ASP.NET MVC 伍 – 创制连接字符串(Connection
String)并选拔SQL Server
LocalDB》.

     领悟LocalDB之后,大家什么样让我们的ASP.NET
MVC项目能访问呢?首先,大家需求安装大家的门类,将数据库文件包括到品种中:

     美高梅开户网址 53

  然后再次发表。

然后在站点物理路径对于的应用程序目录下会有对于的App_Data文件夹,个中蕴藏了大家的数据库文件。

而后打开 SQL Management Studio.并运用(LocalDb)\v11.0,Windows
身份验证登6,然后附加我们项目标数据库。

跟着在IIS中期维修改项目相应应用程序池的标识为”Local
System”。原因参考这里.

 

在形成以上全部手续之后,大家的兼具工作便1度做到了,在浏览器中输入地方就能够访问大家的Web了。附图两张:

美高梅开户网址 54

美高梅开户网址 55

  

        

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图