【4858.com】图像和文字详解远程铺排ASP,成立实体框架数据模型

By admin in 4858.com on 2019年3月25日

真以为温馨的知识面照旧比较窄,在此之前,居然还不知晓SqlLocalDb。

Contoso University  Web 应用程序

你会在那几个科目中创设的应用程序是三个简易的高校网站。

用户可以查阅和翻新学生、
课程和导师音讯。那里有多少个显示器,您将开创。

4858.com 1 

4858.com 2

其一网站的用户界面样式向来看似由放手的沙盘,生成的始末,以便本课程能够集中首要精力怎样选择实体框架。

话外篇:

       
在本篇作品中,我们上学怎么选拔实体框架的“Code First Migrations ”(也号称代码先行作用)工具,使用个中的“迁移”作用对模型类举办一些修改,同时一并革新对应数据库的表结构。

SqlLocalDb是什么?其实便是简化SQL Server的本土数据库,能够那样子说,SQL
Server既能够用作长途,也足以做地点,

系统必备组件

方向和荧屏截图在本教程中一经你正在利用Visual Studio
2012或Visual
Studio 二〇一一速成网站,最新的更新与结束二〇一三 年 7 月,安装的 Windows Azure SDK。你能够获得那总体与下部的链接:

Windows Azure SDK 以 Visual Studio
2012

假定你有安装了 Visual
Studio,上面的链接将设置任何缺乏的零部件。假设您从未 Visual Studio,该链接将安装 Visual Studio 二零一二速成网站。您可以应用 Visual Studio 二〇一二年,但一些所需的先后和显示器会迥然区别。

     
 由于觉得本人的机械比较慢,配置不好,所以近期想把后边的品种布局到实验室的服务器上,但是出于常不在实验室,所以在想能无法远距离布置。因而明日专门研究了一晃切实的长河,下边和豪门分享一下。自个儿新手,还望大虾勿喷,有怎么着难点,还望高手辅导。

       
暗许情状下,当您使用实体框架的“Code First Migrations ”工具,实体框架会自行创制贰个数据库。“代码先行功能”首先会添加二个新表到数据库中,以便跟踪数据库的架构是或不是与模型类同步。假如它们不一样台,实体框架会抛出八个错误。那样开发人士在支付时就能更便于地追查难题出在哪些地方,而此外的开发形式就不得不在运作时通过模糊的错误音信查找什么地方出错了。 

而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)。

4858.com 3

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

Razor视图引擎选取,和成立3个单元测试项目的复选框处于清除状态的假期。

单击确定.

4858.com 4

壹 、本文实验环境:

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

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

 4858.com 5

 图1

 

 4858.com 6

图2

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

 4858.com 7

 

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

 4858.com 8

         
5)在推行完Enable-Migrations命令之后(如上海教室所示),会在品种中开创二个新的文本夹“Migrations”, 在那几个文件夹中创建2个Configuration.cs文件。如下图。

 4858.com 9

           6)在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下的革命波浪线,在弹出菜单中选择“解析”菜单项,然后在弹出菜单中选取“MvcApplication1.Models”;如下图。

 4858.com 10

在经过如此做了以后,Visual Studio会自动在代码中扩展using语句如下:

 

using MvcApplication1.Models;

 

 

       
在“程序包管理器控制台”窗口中履行了“Code First Migrations ”作用中的“迁移”命名之后,代码会活动调用Send 方法(即程序包管理器控制台会调用此措施立异数据库中的数据),并且实施该方式时只要代码中的对象数据不存在则插入,假使存在则展开立异。 

② 、迁移数据库
       1) 若是此刻在Visual Studio中按Ctrl-Shift-B(恐怕菜单–>生成–>生成解决方案)来编写翻译项目,将会现出编写翻译不了的失实。如下图。 
       2) 接下来要确立一个DbMigration类来展开开端迁移。使用那个迁移命名创制二个新的数据库,那便是为啥自身在上一步中删除了Test.mdf文件。 
      
3) 在先后包管理器控制台窗口中,输入指令“dd-migration Initial”成立起来迁移。在那之中“Initial”的命名是随便的,是用来命名新成立的迁移文件。如下图。

 4858.com 11

 

          
4)“Code First Migrations ”功用中的“迁移”命名会在搬迁文件夹中的创立二个新的类公事(名为{DATESTAMP}_Initial.cs),而且以此类中早就包蕴了创建数据库架构的代码。迁移文件名的命名规则中有八个定点的光阴戳,用以协助排序。检查{DATESTAMP}_Initial.cs文件,它富含了创立Books表的数据库的注脚。这一个{DATESTAMP}_Initial.cs文件将运行并创造数据库架构。然后运转Send方法为数据库填充测试数据。 
          
5) 在程序包管理器控制台,输入指令“update-database”来成立数据库,并实施Send方法。如下图1,图2。

 4858.com 12

 图1

4858.com 13

【4858.com】图像和文字详解远程铺排ASP,成立实体框架数据模型。 

图2

 

      
假诺您收获3个荒谬,提示表已经存在,无法被创立,它恐怕是因为您正在周转应用程序,在你剔除了数据库之后,执行更新数据库以前。(如上海教室1)。

      在那种气象下,再度删除Test.mdf文件,然后重试“update-database”命令。如上图2。借使照旧现身错误,请删除该公文夹和剧情,然后起初在那几个页面包车型大巴顶部(也正是剔除Test.mdf文件然后开始展览启用,迁移)的印证。 
          6) 按F5周转应用程序,在浏览器中浏览Books/Index网址。会展现Send方法中填充到数据库中的数据。如下图。

 4858.com 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();
}

按 CTCRUISERL + F5 以运维网站。你看到主页与主菜单。

4858.com 15

      Windows Server 2012 R2

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

创办数据模型

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

4858.com 16

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

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

借使您尝试编写翻译该类型,在你成功全部那些实体类的开创在此之前,你就会获得编写翻译器错误。

      SQL Server 2012 Express

1)要是设置过Visual Studio 201伍 、2017,一般已经设置到了微机里。

学员实体

4858.com 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个性是三个导航属性。导航属性持有此实体相关的其余实体。在那种景色下,五个Student实体的Enrollments属性将保留全部的Enrollment实业的充裕Student实体相关的。换言之,借使某一给定的Student行在数据库中有多个有关的Enrollment
(包括在其StudentID的外键列中的那么些学生主键值的行),该Student实体Enrollments导航属性将富含这四个Enrollment实体。

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

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

     Visual Studio 2013

     那里以Visual Studio 2017为例,在Visual Studio
Installer中的单个组件页面中,可以看看该器件已经被安装(藤黄框框部分):

登记实体

4858.com 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个性是1个外键,且相应的领航属性是StudentEnrollment实业是与二个Student实业相关联,所以该属性只好容纳2个纯粹的Student实体
(不像Student.Enrollments导航属性你前边所述,而数组能够存放三个Enrollment实体)。

CourseID属性是二个外键,且相应的领航属性CourseEnrollment实业是与一个Course实业相关联。

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

 
  4858.com 19

课程实体

4858.com 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质量是1个导航属性。Course实体能够与人身自由数量的Enrollment实体。

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

② 、使用Web
Deploy远程计划的规格

2)也许到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>();
        }
    }
}

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

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 2011及现在的版本中,暗许意况下,Visual Studio 安装 LocalDB。在 Visual Studio 二〇一〇 及更早版本中,在默许意况下,Visual
Studio ; 安装 SQL Server Express (无 LocalDB)您必须手动安装它,假使您使用的 Visual Studio 二零零六。

在本教程中您将使用
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 ) 相同的接连字符串。您已经拉长的接连字符串钦命三个名为ContosoUniversity.mdf位于App_Data文本夹中的
LocalDB 数据库。更加多的新闻,请参见ASP.NET
Web 应用程序的 SQL
服务器连接字符串.

实则,您不必要内定的连天字符串。即使你不提供连接字符串,实体框架将创制二个为您
;不过,数据库只怕无法在你的应用程序的App_data文本夹中。将开创数据库的消息,请参见代码第①遍到新的数据库.

connectionStrings集聚还具备贰个名为DefaultConnection的用于成员身份数据库的接二连三字符串。在本教程中,您不会选取成员身价数据库。三个连续字符串之间的绝无仅有不一致是数据库名称和称号属性值。

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

   
 4858.com 21

安装和履行代码第②次迁移

当您首先次始发开发应用程序时,您的数据模型更改频仍,而且每一遍获得与数据库分歧台的模子更改。您能够配备实体框架能够活动删除并再一次创造该数据库的历次变更数据模型。这不是三个题材在支付的早期,因为测试数据是很不难重新创建,可是你已经铺排到生育后你平时想要更新数据库框架结构,而不删除数据库。迁移成效使代码第二要翻新数据库,而不会删除比量齐观复创立它。早在开发周期中的三个新的品类你恐怕想要使用DropCreateDatabaseIfModelChanges.aspx) ,能够去除、
重新创造和重复安装为种子数据库每便模型更改。一位,你准备布署您的应用程序,您能够转移为的迁徙方法。在本教程中,您将仅使用迁移。有关的详细音信,请参见代码第一回迁移和搬迁截屏录像体系.

 

    32位:

启用代码第①遍迁移

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

    4858.com 22

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

    enable-migrations -contexttypename SchoolContext
    

    4858.com 23

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

    4858.com 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回创造或更新它。

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

 
  4858.com 25

建立了种子法

种子.aspx)方法运营时代码第贰遍迁移成立数据库和每2遍它将创新到最新的迁徙数据库。种子法的指标是为着使你能够将数据插入到表在此之前应用程序访问数据库第2遍。

在早期版本的代码优先,迁移被假释在此以前,它是通常的Seed艺术来插入测试数据,因为在开发进度中的每种模型修改数据库不得不被完全除去和再度创制从零开始。与代码第1遍迁移,测试数据保存后数据库更改,由此包涵种子.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"
    

        4858.com 26       

3)到SQL
Server4858.com ,下载核心下载SQL
Server
Express:

    之后点击下一步: 

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

       4858.com 27

4858.com 28

       4858.com 29

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

       4858.com 30

4858.com 31

      在那边需求勾选“管理服务”,这一步13分关键。

注:SQL Server 二〇一五 Express
LocalDB微软已经不再提供,近来为新型的,约等于上述的2017本子。

      4858.com 32

4)百度网盘下载:

      之后下一步,等待落成布局即可。完毕之后再服务列表中会多出Web
Management 瑟维斯服务,并保障该服务运行。

4858.com 33

      4858.com 34

4858.com 35

    注意,要是该服务没有运行,恐怕没有启用“管理服务”成效,则在行使Web
Deploy铺排项目时会遭受如下错误:“未能连接到长途总结机,请保管在长途总结机上设置了
Web Deploy 并运行了所需的长河(“Web Management Service”)”:

基于系统项目安装区别的SqlLocalDB。

      4858.com 36

第二、连接SqlLocalDB

     
3.布置好管理服务之后,接下去须求进入IIS中经过管克服务来开始展览相应的装置:

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

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

4858.com 37

      4858.com 38

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

     
双击管理服务,对IIS进行布局,这里本身保持了暗中认可的设置,您能够依据自个儿的气象进行设置:

4858.com 39

     4858.com 40

接下来附加三个称谓为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文件的不二法门改为相对路径:

    4858.com 41

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

    然后点击”添加用户”:

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

    4858.com 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}"));
        }
    }
}

   4858.com 43

运转结果如下:

   配置达成今后,接下去需求安装站点的用户权限。

4858.com 44

 
5.布局站点用户权限

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

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

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

  4858.com 45

  之后点击“允许用户”:

 

 4858.com 46

 将在此以前我们抬高的iepi用户拉长到选拔的站点权限中:

 4858.com 47

末段点击分明,配置截止。

 三 、使用Visual Studio
二零一二远程布署项目

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

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

4858.com 48

 

如若没有实行以上的权位配置则会在昭示的时候提示不可能在站点的物理目录下创办理文件件,没有创制权限。

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

 

右键项目选拔”发布”:

  4858.com 49

 

   然后新建二个布局文件,当然也足以选拔在此之前的,建议新建1个。

  4858.com 50

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

  4858.com 51

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

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

        用户密码即为上边大家安插的用户密码。

       
指标UEscortL:一般格式:

     
 之后点击验证,出现4858.com 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 5 – 创建连接字符串(Connection
String)并使用SQL Server
LocalDB》.

     精晓LocalDB之后,大家如何让大家的ASP.NET
MVC项目能访问呢?首先,大家供给安装大家的档次,将数据库文件包涵到项目中:

     4858.com 53

  然后再一次公布。

从此在站点物理路径对于的应用程序目录下会有对于的App_Data文件夹,当中饱含了我们的数据库文件。

日后打开 SQL Management Studio.并应用(LocalDb)\v11.0,Windows
身份验证登陆,然后附加大家项目标数据库。

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

 

在做到上述全部手续之后,大家的拥有工作便早已达成了,在浏览器中输入地方就足以访问大家的Web了。附图两张:

4858.com 54

4858.com 55

  

        

发表评论

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

网站地图xml地图
Copyright @ 2010-2019 美高梅手机版4858 版权所有