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

Contoso University  Web 应用程序

你会在这几个科目中创设的应用程序是2个大致的大学网址。

用户可以查看和换代学生、
课程和教授新闻。那里有多少个显示器,您将成立。

金沙注册送58 1 

金沙注册送58 2

这么些网址的用户界面样式一贯看似由松手的模版,生成的内容,以便本学科能够集中重要精力怎么着选取实体框架。

话外篇:

       
在本篇文章中,我们上学怎么使用实体框架的“Code First Migrations ”(也号称代码先行作用)工具,使用在那之中的“迁移”功效对模型类举行部分修改,同时3头更新对应数据库的表结构。

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

系统必备组件

大势和显示屏截图在本教程中假设你正在利用Visual Studio
2012或Visual
Studio 2013速成网址,最新的翻新与结束201三 年 7 月,安装的 Windows Azure SDK。你能够收获那整个与下部的链接:

Windows Azure SDK 以 Visual Studio
2012

新手入门教程之一,图像和文字详解远程布署ASP。若果您有安装了 Visual
Studio,上边的链接将安装任何缺乏的零件。固然您从未 Visual Studio,该链接将安装 Visual Studio 二〇一三速成网址。您能够选用 Visual Studio 20一叁年,但1些所需的程序和显示器会迥然不一致。

     
 由于觉得自身的机器相比较慢,配置糟糕,所以近期想把前边的档次布局到实验室的服务器上,可是由于常不在实验室,所以在想能或不能够近距离安插。由此明日专门探讨了须臾间具体的长河,上面和豪门分享一下。自己新手,还望大虾勿喷,有如何难点,还望高手引导。

       
默许意况下,当你使用实体框架的“Code First Migrations ”工具,实体框架会自动创制三个数据库。“代码先行成效”首先会添加一个新表到数据库中,以便跟踪数据库的框架结构是不是与模型类同步。假使它们不一起,实体框架会抛出3个不当。那样开发人士在付出时就能更易于地追查难题出在什么样地方,而任何的开发格局就只可以在运行时通过模糊的错误新闻查找什么地点出错了。 

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

制造 MVC Web 应用程序

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

金沙注册送58 3

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

Razor视图引擎选拔,和创造1个单元测试项目的复选框处于清除状态的休假。

单击确定.

金沙注册送58 4

壹、本文实验环境:

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

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

 金沙注册送58 5

 图1

 

 金沙注册送58 6

图2

      二)执行菜单–》工具–》生成–》生成消除方案,以保证未有不当。 
       三)从菜系–》工具菜单中,单击库程序包管理器–》程序包管理器控制台。如下图。

 金沙注册送58 7

 

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

 金沙注册送58 8

         
五)在实践完Enable-Migrations命令之后(如上海体育地方所示),会在类型中开创贰个新的文书夹“Migrations”, 在那一个文件夹中开创三个Configuration.cs文件。如下图。

 金沙注册送58 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,

         }

   );
        }

    }

}

 

           7)使用鼠标右键单击Book下的红色波(英文名:lán bō)浪线,在弹出菜单中采用“解析”菜单项,然后在弹出菜单中选用“MvcApplication壹.Models”;如下图。

 金沙注册送58 10

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

 

using MvcApplication1.Models;

 

 

       
在“程序包管理器控制台”窗口中施行了“Code First Migrations ”成效中的“迁移”命名之后,代码会自动调用Send 方法(即程序包管理器控制台会调用此形式创新数据库中的数据),并且实施该方法时若是代码中的对象数据不设有则插入,假设存在则开始展览创新。 

二、迁移数据库
       一) 即使那时候在Visual Studio中按Ctrl-Shift-B(可能菜单–>生成–>生成化解方案)来编写翻译项目,将会冒出编写翻译不了的荒唐。如下图。 
       二) 接下来要创制三个DbMigration类来进展开首迁移。使用这一个迁移命名创制一个新的数据库,那正是为啥我在上一步中删去了Test.mdf文件。 
      
三) 在先后包管理器控制台窗口中,输入指令“dd-migration Initial”创立起来迁移。个中“Initial”的命名是随便的,是用来命名新创立的迁移文件。如下图。

 金沙注册送58 11

 

          
四)“Code First Migrations ”功效中的“迁移”命名会在搬迁文件夹中的创制三个新的类公事(名叫{DATESTAMP}_Initial.cs),而且以此类中早就包蕴了创立数据库架构的代码。迁移文件名的命名规则中有二个稳住的胎元戳,用以帮忙排序。检查{DATESTAMP}_Initial.cs文件,它涵盖了创立Books表的数据库的验证。那些{DATESTAMP}_Initial.cs文件将运转并创制数据库架构。然后运营Send方法为数据库填充测试数据。 
          
5) 在程序包管理器控制台,输入指令“update-database”来制造数据库,并履行Send方法。如下图一,图2。

 金沙注册送58 12

 图1

金沙注册送58 13

 

图2

 

      
如若您取得一个不当,提醒表已经存在,不能够被创设,它只怕是因为您正在周转应用程序,在您剔除了数据库之后,执行更新数据库从前。(如上海体育场面1)。

      在那种情状下,再次删除Test.mdf文件,然后重试“update-database”命令。如上航海用教室二。要是依然出现错误,请删除该公文夹和情节,然后开头在这些页面包车型客车顶部(也正是删除Test.mdf文件然后开始展览启用,迁移)的表明。 
          陆) 按F伍运营应用程序,在浏览器中浏览Books/Index网站。会显得Send方法中填充到数据库中的数据。如下图。

 金沙注册送58 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();
}

按 CTBMWX伍L + F5 以运转网址。你看到主页与主菜单。

金沙注册送58 15

      Windows Server 2012 R2

先是,怎么设置这几个SqlLocalDb?

成立数据模型

接下去,您将开创实体类为 Contoso
University 中的应用。你将上马与以下八个实体:

金沙注册送58 16

还有StudentEnrollment实业之间的2个一对多关系和CourseEnrollment实体之间是壹对多的涉嫌。换句话说,学生能够在任意数量的学科,并自然能够有专断数量的学员参预了它。

在以下壹些中,您将创造3个类,用于每个这么些实体。

设若您尝试编写翻译该类型,在你成就具有这么些实体类的开创在此之前,你就会博得编写翻译器错误。

      SQL Server 2012 Express

壹)如若设置过Visual Studio 20一伍、20一七,1般已经设置到了总括机里。

学生实体

金沙注册送58 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本性是多个导航属性。导航属性持有此实体相关的任何实体。在那种情景下,3个Student实体的Enrollments质量将保存全部的Enrollment实体的尤其Student实体相关的。换言之,假如某1给定的Student行在数据库中有三个有关的Enrollment
(包罗在其StudentID的外键列中的那么些学生主键值的行),该Student实体Enrollments导航属性将包罗那五个Enrollment实体。

导航属性常常定义为virtual中,以便他们能够应用有个别实体框架效能,如延期加载。(延迟加载将稍后解释,读取相关数据课程稍后在本连串中。

比方1个导航属性能够包容多少个实体
(如多多或2个一对多涉及),其项目必须是1个列表条目能够被添加、
删除和更新,如ICollection.

     Visual Studio 2013

     这里以Visual Studio 201七为例,在Visual Studio
Installer中的单个组件页面中,能够看看该器件已经棉被服装置(灰湖绿框框部分):

注册实体

金沙注册送58 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实业是与1个Student实业相关联,所以该属性只好容纳四个纯净的Student实体
(不像Student.Enrollments导航属性你前边所述,而数组可以存放多少个Enrollment实体)。

CourseID天性是多少个外键,且相应的导航属性CourseEnrollment实业是与一个Course实业相关联。

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

 
  金沙注册送58 19

金沙注册送58 ,课程实体

金沙注册送58 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个性是2个导航属性。Course实业可以与自由数量的Enrollment实体。

咱俩会说越来越多关于[DatabaseGenerated(DatabaseGeneratedOption.None)]在接下去的教程中的属性。基本上,此属性允许你为该学科而不是变化的数据库输入的主键。

2、使用Web
Deploy远程安顿的尺度

2)可能到Visual Studio 2017安装包安装该零件:

创建Database Context

坐标给定的数据模型的实业框架效用的主类是数据库上下文类。通过从System.Data.Entity.DbContext.aspx)类派生来创设此类。在您的代码中你钦命数据模型中包蕴什么样实体。您还足以自定义有些实体框架作为。在这些体系中,类名字为SchoolContext.

创办1个文件夹命名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>();
        }
    }
}

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

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 越发不引入用于生产1个 web
应用程序因为它不规划工作的私下入境者。

在 Visual Studio 2012及之后的版本中,默许情形下,Visual Studio 安装 LocalDB。在 Visual Studio 20拾 及更早版本中,在暗中同意情况下,Visual
Studio ; 安装 SQL Server Express (无 LocalDB)您必须手动安装它,假如你利用的 Visual Studio 20十。

在本教程中你将利用
LocalDB,以便数据库能够储存在.mdf文本所在的App_Data文本夹中。打开根Web.config文本并到connectionStrings集结中,添加四个新的连日字符串,如上面包车型大巴言传身教所示。(请确定保证您更新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 ) 相同的连年字符串。您已经添加的总是字符串钦点2个名字为ContosoUniversity.mdf位于App_Data文件夹中的
LocalDB 数据库。越多的音信,请参见ASP.NET
Web 应用程序的 SQL
服务器连接字符串.

事实上,您不须要钦赐的连天字符串。若是你不提供连接字符串,实体框架将开创贰个为您
;可是,数据库或然不恐怕在你的应用程序的App_data文本夹中。将创制数据库的新闻,请参见代码第三次到新的数据库.

connectionStrings相会还存有二个名字为DefaultConnection的用来成员身份数据库的连日字符串。在本教程中,您不会使用成员身份数据库。七个接二连三字符串之间的唯一区别是数据库名称和称号属性值。

       1.供给安装Web
Deploy ,上边地址:http://www.iis.net/downloads/microsoft/web-deploy

   
 金沙注册送58 21

设置和举办代码第一回迁移

当你首先次始发开发应用程序时,您的数据模型更改频仍,而且每回得到与数据库区别步的模子更改。您能够安顿实体框架能够自行删除并再一次创建该数据库的历次变更数据模型。那不是2个题材在支付的早期,因为测试数据是很不难重新创立,不过你曾经布置到生育后你日常想要更新数据库架构,而不删除数据库。迁移作用使代码第二要创新数据库,而不会删除同等看待新成立它。早在开发周期中的3个新的连串你大概想要使用DropCreateDatabaseIfModelChanges.aspx) ,能够去除、
重新创造和另行设置为种子数据库每便模型更改。一位,你准备布署您的应用程序,您能够转移为的动员搬迁方法。在本教程中,您将仅使用迁移。有关的详细音讯,请参见代码第二回迁移和搬迁截屏录像种类.

 

    32位:

启用代码第壹遍迁移

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

    金沙注册送58 22

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

    enable-migrations -contexttypename SchoolContext
    

    金沙注册送58 23

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

    金沙注册送58 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措施的目标是使你能够向数据库中插入测试数据后代码第1遍成立或更新它。

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

 
  金沙注册送58 25

建立了种子法

种子.aspx)方法运维时期码第一回迁移创立数据库和每叁回它将革新到最新的迁徙数据库。种子法的指标是为着使你能够将数据插入到表从前应用程序访问数据库第三遍。

在最初版本的代码优先,迁移被放出从前,它是日常的Seed方法来插入测试数据,因为在付出进度中的各样模型修改数据库不得不被统统除去和另行创制从零初阶。与代码第3回迁移,测试数据保存后数据库更改,由此包含种子.aspx)方法中的测试数据壹般不是至关重要。事实上,你不想要插入测试数据,借使你将运用迁移将数据库布署到生产,因为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"
    

        金沙注册送58 26       

3)到SQL
Server下载核心下载SQL
Server
Express:

    之后点击下一步: 

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

       金沙注册送58 27

金沙注册送58 28

       金沙注册送58 29

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

       金沙注册送58 30

金沙注册送58 31

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

注:SQL Server 201陆 Express
LocalDB微软已经不再提供,方今为新型的,也正是上述的20一七本子。

      金沙注册送58 32

4)百度网盘下载:

      之后下一步,等待达成安插即可。完结之后再服务列表中会多出Web
Management Service服务,并确定保证该服务运营。

金沙注册送58 33

      金沙注册送58 34

金沙注册送58 35

    注意,借使该服务未有运转,可能尚未启用“管理服务”功用,则在利用Web
Deploy布置项目时会遭受如下错误:“未能连接到长途计算机,请确认保证在长距离总结机上安装了
Web Deploy 并运维了所需的进度(“Web Management Service”)”:

根据系统项目安装差别的SqlLocalDB。

      金沙注册送58 36

第二、连接SqlLocalDB

     
3.安插好管理服务之后,接下去须求进入IIS中经过管理服务来拓展相应的装置:

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

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

金沙注册送58 37

      金沙注册送58 38

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

     
双击管理服务,对IIS举行布局,那里作者保持了默许的设置,您能够依据自身的状况举办设置:

金沙注册送58 39

     金沙注册送58 40

接下来附加3个名号为MusicDBContext.mdf的数据库文件(文件能够团结定义)并点击明确,此时,MusicDBContext.数据库作为私下认可的数据库,我们可以选用SQLLocalDB中的其余已有数据库。

     四.安顿远布置Web项指标账户

变动的接连字符串如下:

   
基于安全着想,咱们最棒提供单身的账户来安顿Web项目,同时对于IIS中站点,能够钦赐哪些用户才具有铺排应用程序到此站点的权杖。

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

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

我们能够将mdf文件的路子改为相对路径:

    金沙注册送58 41

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

    然后点击”添加用户”:

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

    金沙注册送58 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}"));
        }
    }
}

   金沙注册送58 43

运营结果如下:

   配置完毕之后,接下去要求安装站点的用户权限。

金沙注册送58 44

 
伍.计划站点用户权限

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

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

第伍、一些关于SqlLocalDB的参考资料

  金沙注册送58 45

  之后点击“允许用户”:

 

 金沙注册送58 46

 将事先咱们抬高的iepi用户拉长到选择的站点权限中:

 金沙注册送58 47

终极点击明确,配置截止。

 三、使用Visual Studio
2013长距离陈设项目

在发表项目事先,大家要求对即将宣布的站点(例如那里的
Default Web Site)根目录举办部分权力配置。也正是”Local 瑟维斯”账户须求有改动站点目录的权柄。那里大家的“Default Web
Site”的目录对于着:

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

金沙注册送58 48

 

1旦没有进展上述的权杖配置则会在昭示的时候唤醒不能在站点的情理目录下创办理文件件,未有成立权限。

在配备好站点的大体目录权限之后我们初叶发布web项目:

 

右键项目采纳”公布”:

  金沙注册送58 49

 

   然后新建1个安排文件,当然也足以挑选此前的,提出新建1个。

  金沙注册送58 50

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

  金沙注册送58 51

表达:服务器:输入IP地址即可

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

        用户密码即为上边大家配备的用户密码。

       
指标UHighlanderL:1般格式:

     
 之后点击验证,出现金沙注册送58 52意味着音信无误,能够拓展发表了。接下来点击下一步,直到发布实现,那里由于大家采用的是LocalDB,因而大家不用进行数据库配置。

四、配置LocalDb数据库

       LocalDB的是一个SQL Server Express轻量级版本的数据库引擎。
它在用户方式下运营、执行。LocalDB的运转在3个万分的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项目能访问呢?首先,大家需求设置大家的类型,将数据库文件包蕴到品种中:

     金沙注册送58 53

  然后再次宣布。

而后在站点物理路径对于的应用程序目录下会有对于的App_Data文件夹,当中包涵了咱们的数据库文件。

后来打开 SQL Management Studio.并采纳(LocalDb)\v1壹.0,Windows
身份验证登6,然后附加我们项指标数据库。

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

 

在达成以上全体手续之后,大家的具有工作便已经到位了,在浏览器中输入地方就能够访问大家的Web了。附图两张:

金沙注册送58 54

金沙注册送58 55

  

        

相关文章

网站地图xml地图