ASP.NET Core 设置和初始化数据库 - ASP.NET Core 基础教程 - 简单教程,简单编程

原文:ASP.NET Core 设置和初始化数据库 - ASP.NET Core 基础教程 - 简单教程,简单编程

ASP.NET Core 设置和初始化数据库

上一章节中我们已经设置和配置好了 EF 框架服务,本章节我们就来学习如何使用 EF 框架设置和初始化数据库

初始化数据库

初始化数据库的方法之一是使用 EF 框架来创建数据库,仅仅需要两步就能完成

  1. 第一步,给我们的 HelloWorld 项目添加迁移 ( migration ) 代码

    迁移代码是 C# 代码,用来在数据库系统中创建数据库

    当然了,EF 框架可以自动帮我们生成迁移代码

    EF 框架通过对比数据库和我们的模型,并计算出所需的数据库表的更改

    当我们添加其它的模型或对现有模型进行更改 ( 如 Employee 类 )时,我们可以使用 EF 框架创建新的迁移来保持我们的数据库表同步

  2. 第二步,执行迁移代码,更新数据库,也就是说,我们需要明确地应用这些迁移来更新数据库

这两步任务都可以通过在 控制台窗口 ( 终端或 Power Shell 或 命令提示符 ) 中使用一些简单的命令来实现

好吧,开始吧

  1. 首先打开 控制台窗口 ( 终端或 Power Shell 或 命令提示符 ),定位到我们的 HelloWorld 项目下

    $ cd ~/Developer/aspnetcore/HelloWorld/HelloWorld
    

    我用的是 macOS,且我的 HelloWorld 保存在 ~/Developer/aspnetcore/HelloWorld/HelloWorld

    然后使用 ls 命名就可以列出当前目录下的所有文件和子目录

    $ ls
    AppSettings.json  Controllers  HelloWorld.csproj  Models  Program.cs  Properties  Startup.cs  Views  bin  obj  wwwroot
    

    如果你使用的是 Windows,且使用的不是 Power Shell,那么你应该使用 dir 命令而不是 ls 命令

    如果能看到 HelloWorld.csproj 则说明处于正确的目录,否则你应该继续 cd 到该目录下

  2. 然后可以运行下列命令创建迁移代码
    dotnet ef migrations add InitialCreate -v
    
    参数 说明
    dotnet 是 .NET 框架所有命令的开始标识
    ef 是指使用 Entity Framework 提供的命令
    migrations 是指使用迁移命令
    add 是指添加迁移
    InitialCreate 是本次迁移的说明,你可以改成任意文本,但我们推荐最好是能清楚的描述本次迁移的意图
    -v 参数用于输出创建迁移代码时的运行日志,方便出错时我们可以查看错在哪里

    运行失败... 你知道有多坑吗,我写这个教程的时候才 2.1.0,写到一半变成了 2.1.1 了

    运行结果如下

    $ dotnet ef migrations add InitialCreate -v
    Using project ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj‘.
    Using startup project ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj‘.
    Writing ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/obj/HelloWorld.csproj.EntityFrameworkCore.targets‘...
    dotnet msbuild /target:GetEFProjectMetadata /property:EFProjectMetadataFile=/var/folders/yk/2446sljj6hn82nvzkdgxltmw0000gn/T/tmp9Zm0P4.tmp /verbosity:quiet /nologo /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj
    Writing ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/obj/HelloWorld.csproj.EntityFrameworkCore.targets‘...
    dotnet msbuild /target:GetEFProjectMetadata /property:EFProjectMetadataFile=/var/folders/yk/2446sljj6hn82nvzkdgxltmw0000gn/T/tmpQa9wxL.tmp /verbosity:quiet /nologo /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj
    dotnet build /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj /verbosity:quiet /nologo
    
    Build succeeded.
        0 Warning(s)
        0 Error(s)
    
    Time Elapsed 00:00:05.31
    dotnet exec --depsfile /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1/HelloWorld.deps.json --additionalprobingpath /Users/yufei/.nuget/packages --additionalprobingpath /usr/local/share/dotnet/sdk/NuGetFallbackFolder --runtimeconfig /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1/HelloWorld.runtimeconfig.json /usr/local/share/dotnet/sdk/2.1.301/DotnetTools/dotnet-ef/2.1.1/tools/netcoreapp2.1/any/tools/netcoreapp2.0/any/ef.dll migrations add InitialCreate --assembly /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1/HelloWorld.dll --startup-assembly /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1/HelloWorld.dll --project-dir /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/ --language C# --working-dir /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld --verbose --root-namespace HelloWorld
    Using assembly ‘HelloWorld‘.
    Using startup assembly ‘HelloWorld‘.
    Using application base ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1‘.
    Using working directory ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld‘.
    Using root namespace ‘HelloWorld‘.
    Using project directory ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/‘.
    Finding DbContext classes...
    Finding IDesignTimeDbContextFactory implementations...
    Finding application service provider...
    Finding IWebHost accessor...
    Using environment ‘Development‘.
    Using application service provider from IWebHost accessor on ‘Program‘.
    Found DbContext ‘HelloWorldDBContext‘.
    Finding DbContext classes in the project...
    Using context ‘HelloWorldDBContext‘.
    info: Microsoft.EntityFrameworkCore.Infrastructure[10403]
          Entity Framework Core 2.1.1-rtm-30846 initialized ‘HelloWorldDBContext‘ using provider ‘Microsoft.EntityFrameworkCore.Sqlite‘ with options: None
    Finding design-time services for provider ‘Microsoft.EntityFrameworkCore.Sqlite‘...
    Using design-time services from provider ‘Microsoft.EntityFrameworkCore.Sqlite‘.
    Finding design-time services referenced by assembly ‘HelloWorld‘.
    No referenced design-time services were found.
    Finding IDesignTimeServices implementations in assembly ‘HelloWorld‘...
    No design-time services were found.
    Writing migration to ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/Migrations/20180623011047_InitialCreate.cs‘.
    Writing model snapshot to ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/Migrations/HelloWorldDBContextModelSnapshot.cs‘.
    Done. To undo this action, use ‘ef migrations remove‘
    

    大概意思就是经过漫长的岁月,成功创建了迁移代码

    这一步非常容易出错,如果你有任何错误,欢迎你在讨论区留下你包括的意见

    ASP.NET Core 讨论区

  3. 创建迁移成功后,我们就可以使用下面的命令查看当前有多少迁移代码和它们的状态
    $ dotnet ef migrations list
    

    运行结果如下

    $ dotnet ef migrations list
    info: Microsoft.EntityFrameworkCore.Infrastructure[10403]
    Entity Framework Core 2.1.1-rtm-30846 initialized ‘HelloWorldDBContext‘ using provider ‘Microsoft.EntityFrameworkCore.Sqlite‘ with options: None
    20180623011249_InitialCreate
    

    可以看到总共有一个迁移代码,那就是 20180623011249_InitialCreate

    在解决方案管理器中我们还可以看到多出了一个目录 Migrations 和多个文件

  4. 接下来我们就要开始应用这些迁移来更新数据库,执行下面的命令来应用迁移代码
    $ dotnet ef database update -v
    
    参数 说明
    dotnet 是 .NET 框架所有命令的开始标识
    ef 是指使用 Entity Framework 提供的命令
    database 是指使用数据库相关命令
    update 是指更新数据库
    -v 参数用于输出创建迁移代码时的运行日志,方便出错时我们可以查看错在哪里

    执行以上命令,输出结果如下

    $ dotnet ef database update -v
    Using project ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj‘.
    Using startup project ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj‘.
    Writing ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/obj/HelloWorld.csproj.EntityFrameworkCore.targets‘...
    dotnet msbuild /target:GetEFProjectMetadata /property:EFProjectMetadataFile=/var/folders/yk/2446sljj6hn82nvzkdgxltmw0000gn/T/tmpDJ7JJ2.tmp /verbosity:quiet /nologo /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj
    Writing ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/obj/HelloWorld.csproj.EntityFrameworkCore.targets‘...
    dotnet msbuild /target:GetEFProjectMetadata /property:EFProjectMetadataFile=/var/folders/yk/2446sljj6hn82nvzkdgxltmw0000gn/T/tmpjmGX4s.tmp /verbosity:quiet /nologo /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj
    dotnet build /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/HelloWorld.csproj /verbosity:quiet /nologo
    
    Build succeeded.
        0 Warning(s)
        0 Error(s)
    
    Time Elapsed 00:00:04.26
    dotnet exec --depsfile /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1/HelloWorld.deps.json --additionalprobingpath /Users/yufei/.nuget/packages --additionalprobingpath /usr/local/share/dotnet/sdk/NuGetFallbackFolder --runtimeconfig /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1/HelloWorld.runtimeconfig.json /usr/local/share/dotnet/sdk/2.1.301/DotnetTools/dotnet-ef/2.1.1/tools/netcoreapp2.1/any/tools/netcoreapp2.0/any/ef.dll database update --assembly /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1/HelloWorld.dll --startup-assembly /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1/HelloWorld.dll --project-dir /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/ --language C# --working-dir /Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld --verbose --root-namespace HelloWorld
    Using assembly ‘HelloWorld‘.
    Using startup assembly ‘HelloWorld‘.
    Using application base ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/bin/Debug/netcoreapp2.1‘.
    Using working directory ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld‘.
    Using root namespace ‘HelloWorld‘.
    Using project directory ‘/Users/yufei/Developer/aspnetcore/HelloWorld/HelloWorld/‘.
    Finding DbContext classes...
    Finding IDesignTimeDbContextFactory implementations...
    Finding application service provider...
    Finding IWebHost accessor...
    Using environment ‘Development‘.
    Using application service provider from IWebHost accessor on ‘Program‘.
    Found DbContext ‘HelloWorldDBContext‘.
    Finding DbContext classes in the project...
    Using context ‘HelloWorldDBContext‘.
    info: Microsoft.EntityFrameworkCore.Infrastructure[10403]
          Entity Framework Core 2.1.1-rtm-30846 initialized ‘HelloWorldDBContext‘ using provider ‘Microsoft.EntityFrameworkCore.Sqlite‘ with options: None
    Finding design-time services for provider ‘Microsoft.EntityFrameworkCore.Sqlite‘...
    Using design-time services from provider ‘Microsoft.EntityFrameworkCore.Sqlite‘.
    Finding design-time services referenced by assembly ‘HelloWorld‘.
    No referenced design-time services were found.
    Finding IDesignTimeServices implementations in assembly ‘HelloWorld‘...
    No design-time services were found.
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (28ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          PRAGMA foreign_keys=ON;
    Executed DbCommand (28ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    PRAGMA foreign_keys=ON;
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          PRAGMA foreign_keys=ON;
    Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    PRAGMA foreign_keys=ON;
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (7ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          CREATE TABLE "__EFMigrationsHistory" (
              "MigrationId" TEXT NOT NULL CONSTRAINT "PK___EFMigrationsHistory" PRIMARY KEY,
              "ProductVersion" TEXT NOT NULL
          );
    Executed DbCommand (7ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    CREATE TABLE "__EFMigrationsHistory" (
        "MigrationId" TEXT NOT NULL CONSTRAINT "PK___EFMigrationsHistory" PRIMARY KEY,
        "ProductVersion" TEXT NOT NULL
    );
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          PRAGMA foreign_keys=ON;
    Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    PRAGMA foreign_keys=ON;
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          PRAGMA foreign_keys=ON;
    Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    PRAGMA foreign_keys=ON;
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (8ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          SELECT COUNT(*) FROM "sqlite_master" WHERE "name" = ‘__EFMigrationsHistory‘ AND "type" = ‘table‘;
    Executed DbCommand (8ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    SELECT COUNT(*) FROM "sqlite_master" WHERE "name" = ‘__EFMigrationsHistory‘ AND "type" = ‘table‘;
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          PRAGMA foreign_keys=ON;
    Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    PRAGMA foreign_keys=ON;
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (1ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          SELECT "MigrationId", "ProductVersion"
          FROM "__EFMigrationsHistory"
          ORDER BY "MigrationId";
    Executed DbCommand (1ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    SELECT "MigrationId", "ProductVersion"
    FROM "__EFMigrationsHistory"
    ORDER BY "MigrationId";
    info: Microsoft.EntityFrameworkCore.Migrations[20402]
          Applying migration ‘20180623011249_InitialCreate‘.
    Applying migration ‘20180623011249_InitialCreate‘.
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          PRAGMA foreign_keys=ON;
    Executed DbCommand (0ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    PRAGMA foreign_keys=ON;
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (1ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          CREATE TABLE "Employees" (
              "ID" INTEGER NOT NULL CONSTRAINT "PK_Employees" PRIMARY KEY AUTOINCREMENT,
              "Name" TEXT NULL
          );
    Executed DbCommand (1ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    CREATE TABLE "Employees" (
        "ID" INTEGER NOT NULL CONSTRAINT "PK_Employees" PRIMARY KEY AUTOINCREMENT,
        "Name" TEXT NULL
    );
    info: Microsoft.EntityFrameworkCore.Database.Command[20101]
          Executed DbCommand (2ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
          INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
          VALUES (‘20180623011249_InitialCreate‘, ‘2.1.1-rtm-30846‘);
    Executed DbCommand (2ms) [Parameters=[], CommandType=‘Text‘, CommandTimeout=‘30‘]
    INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
    VALUES (‘20180623011249_InitialCreate‘, ‘2.1.1-rtm-30846‘);
    Done.
    

    输出日志很长,大概的意思就是执行成功了

  5. 应用迁移代码成功后我们就能在根目录下发现我们的 blogging.db 文件了

    至于它为什么不在前面章节中提到的 bin/Debug 目录下,我也很疑问,算了,不管了

blogging.db

blogging.db 是一个标准的 SQLite3 数据库文件,我们可以使用 SQLite Studio 打开看看

对了,SQLite Studio 是一个跨平台的软件,你可以点击 https://sqlitestudio.pl/index.rvt?act=download 下载它

使用 SQLite Studio 可以看到我们的 blogging.db 中已经有了表 Employees ,且有两个字段

本章到这里就结束了,我本来想给大家介绍下迁移代码的,但这其实已经超出了基础教程的范畴了,算了,以后有空再来讲讲

原文地址:https://www.cnblogs.com/lonelyxmas/p/9724280.html

时间: 2024-10-05 03:57:33

ASP.NET Core 设置和初始化数据库 - ASP.NET Core 基础教程 - 简单教程,简单编程的相关文章

ASP.NET Core 使用 EF 框架查询数据 - ASP.NET Core 基础教程 - 简单教程,简单编程

原文:ASP.NET Core 使用 EF 框架查询数据 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 使用 EF 框架查询数据 上一章节我们学习了如何设置和初始化数据库,以及如何创建迁移代码和应用迁移代码.本章节我们就学习如何使用 EF 框架来查询数据库,至于添加和修改,后面的章节中我们会慢慢学习到 添加测试数据 我们首先使用 SQLite Studio 添加三条数据 ID Name 1 李白 2 杜甫 3 白居易 使用 SQLite Studio

玩转ASP.NET 5:初始化数据库

1.初始化数据库 1.2目录 这不是专述模式/架构设计的帖子,架构搭建以讲解文章为目的,先不过多分层. 截这个图也是便于你对应下面找代码文件路径! 1.2代码 先控制台应用程序来演示.(比较蛋疼,MS针对ASP.NET 5测试框架在beta1版中,可用XUnit.KRunner.beta2中我也不知道用那个.) 不管你用不用EF?传统做法先设计数据库,但写代码面向对象开发时还是要设计实体(模型),为了方便映射实体的属性和数据库字段是一一对应(也可以通过Fluent API配置,实体属性设计和字段

Asp数据库连接出错,请检查Conn.asp文件中的数据库参数设置

Asp数据库连接出错,请检查Conn.asp文件中的数据库参数设置 解决办法: IIS-本地计算机-应用程序池-DefaultAppPool(右键)-高级设置将"启用32位应用程序"设置为true

ASP.NET Core 数据库上下文 - ASP.NET Core 基础教程 - 简单教程,简单编程

原文:ASP.NET Core 数据库上下文 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 数据库上下文 上一章节中我们了解了 Entity Framework 并讲述了如何配置它.本章节我们就来学习如何使用它 EF 框架 ( Entity Framework ) 使我们能够使用称为实体 ( Entity) 的公共语言运行时 ( CLR ) 对象查询,插入,更新和删除数据 EF 框架将模型中定义的实体和关系映射到数据库.除此之外,它还具有以下能力: 将

ASP.NET Core 配置 EF 框架服务 - ASP.NET Core 基础教程 - 简单教程,简单编程

原文:ASP.NET Core 配置 EF 框架服务 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 配置 EF 框架服务 上一章节中我们了解了 Entity Framework 的基本工作原理和 DbContext ,我们也创建了一个自己的 HelloWorldDBContext. 本章节我们就来讲讲如何设置我们的 EF 框架来链接到 SQLite 数据库 配置 EF 框架服务 要让我们的 EF 框架的 DBContext 能够运行起来,我们需要更改一

ASP.NET Core 配置 Entity Framework Core - ASP.NET Core 基础教程 - 简单教程,简单编程

原文:ASP.NET Core 配置 Entity Framework Core - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 配置 Entity Framework Core 上一章节学习完了视图,其实我们应该立即着手讲解模型的,但 ASP.NET Core MVC 中的模型和 Entity Framework 有相当大的关系,所以,在此之前,我们先来讲讲 Entity Framework Core 和如何配置它 本章中,我们将设置和配置我们的应用程

用asp.net还原与恢复sqlserver数据库

上次做了个项目,涉及到数据库的还原和恢复,到网上找了一下,是利用SQLDMO实现的,只要添加SQLDMO引用就好了,然后利用下边的类的方法就可以实现了.我把原作者的类扩充了一下,可以自动识别web.config里 的数据库连接字符串,可以通过变量设置还原恢复的信息.需要注意的时还原,还原的时候问题最大了,有别的用户使用数据库的时候无法还原,解决办法就是在MASTER数据库中添加一个存储过程:create proc killspid (@dbname varchar(20))asbegindecl

Windows server2008 搭建ASP接口訪问连接oracle数据库全过程记录

真的是太不easy了,曾经的时候在window server 2003上面搭建了一套asp+oracle的接口系统.就费了好大的劲儿,事实上那会迷迷瞪瞪的也不知道怎么的就弄好了,也懒得管了.OK,从昨天到今天打算把接口从測试环境部署到公网环境上去的时候就出现了各种各样的问题.这次一定得记录一下. 先来说一下这套接口系统的总体方案: 之所用选用asp是由于属于轻量级的接口系统,仅仅须要改动好了以后复制粘贴上去接口就马上生效.而不须要像java系的接口程序要用tomcat打包.上传.部署这种.那这个

asp.net如何设置数据库连接池的数量

http://www.cnblogs.com/wbcms/archive/2008/10/11/1308725.html 可以使用一组名称-值对以链接字符串的形式配置链接池.例如,可以配置池是否有效(默认是有效的),池的最大.最小容量,用于打 开链接的排队请求被阻断的时间.下面的示例字符串配置了池的最大和最小容量. "Server=(local); Integrated Security=SSPI; Database=Northwind; Max Pool Size=75; Min Pool S