前回 Model を追加するためのセットアップ では必要なパッケージのインストールを行った。今回は実際にモデルを作成して動かしてみる。
参考 :
- Models という名前のフォルダーを追加します。
やってみる。ホスト側で編集する。
$ cd Projects/RazorPagesMovie
$ ls
Pages Startup.cs obj
Program.cs appsettings.Development.json wwwroot
Properties appsettings.json
RazorPagesMovie.csproj bin
$ mkdir Models
$ ls
Models RazorPagesMovie.csproj bin
Pages Startup.cs obj
Program.cs appsettings.Development.json wwwroot
Properties appsettings.json
できた。
- Movie.cs という名前の Models フォルダーにクラスを追加します。
Movie クラスに次のプロパティを追加します。
using System; using System.ComponentModel.DataAnnotations; namespace RazorPagesMovie.Models { public class Movie { public int ID { get; set; } public string Title { get; set; } [DataType(DataType.Date)] public DateTime ReleaseDate { get; set; } public string Genre { get; set; } public decimal Price { get; set; } } }
Movie
クラスには次が含まれます。
ID
フィールドは、データベースで主キー用に必要です。
[DataType(DataType.Date)]
: DataType 属性では、データの型 (Date) を指定します。 この属性を使用する場合:
- ユーザーは日付フィールドに時刻の情報を入力する必要はありません。
- 日付のみが表示され、時刻の情報は表示されません。
Movies.cs ファイルを作成する。
$ vimr Models/Movie.cs
using System;
using System.ComponentModel.DataAnnotations;
namespace RazorPagesMovie.Models
{
public class Movie
{
public int ID { get; set; }
public string Title { get; set; }
[DataType(DataType.Date)]
public DateTime ReleaseDate { get; set; }
public string Genre { get; set; }
public decimal Price { get; set; }
}
}
できたらしい。
データベース コンテキスト クラスの追加
RazorPagesMovie プロジェクトで、 Data という名前の新しいフォルダーを作成します。 次の
RazorPagesMovieContext
クラスを Data フォルダーに追加します。using Microsoft.EntityFrameworkCore; namespace RazorPagesMovie.Data { public class RazorPagesMovieContext : DbContext { public RazorPagesMovieContext ( DbContextOptions<RazorPagesMovieContext> options) : base(options) { } public DbSet<RazorPagesMovie.Models.Movie> Movie { get; set; } } }
上記のコードによって、エンティティ セットの
DbSet
プロパティが作成されます。 Entity Framework の用語では、エンティティ セットは通常はデータベース テーブルに対応し、 エンティティはテーブルの行に対応します。 このコードは、後の手順で依存関係が追加されるまでコンパイルされません。
これも作成する。 ホスト側で Data ディレクトリを作成し、 Data/RazorPagesMovieContext.cs を作成する。
$ mkdir Data
$ vimr Data/RazorPagesMovieContext.cs
using Microsoft.EntityFrameworkCore;
namespace RazorPagesMovie.Data {
public class RazorPagesMovieContext : DbContext
{
public RazorPagesMovieContext (
DbContextOptions<RazorPagesMovieContext> options
) : base(options)
{}
public DbSet<RazorPagesMovie.Models.Movie> Movie { get; set; }
}
}
できたらしい。
データベース接続文字列の追加
次の強調表示されたコードに示されているように、 appsettings.json ファイルに接続文字列を追加します。
{ "Logging": { "LogLevel": { "Default": "Information", "Microsoft": "Warning", "Microsoft.Hosting.Lifetime": "Information" } }, "AllowedHosts": "*", "ConnectionStrings": { "MovieContext": "Data Source=MvcMovie.db" } }
これもやる。
$ vimr appsettings.json
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft": "Warning",
"Microsoft.Hosting.Lifetime": "Information"
}
},
"AllowedHosts": "*", // コンマ追加
"ConnectionStrings" : { // 追加
"MovieContext" : "Data Source=MvcMovie.db" // 追加
} // 追加
}
まだまだ続く。
データベース コンテキストの登録
Startup.cs の先頭に次の
using
ステートメントを追加します。using RazorPagesMovie.Data; using Microsoft.EntityFrameworkCore;
Startup.ConfigureServices
で 依存性の挿入 コンテナーを使用し、データベース コンテキストを登録します。public void ConfigureServices(IServiceCollection services) { services.AddRazorPages(); services.AddDbContext<RazorPagesMovieContext>(options => options.UseSqlite(Configuration.GetConnectionString("MovieContext"))); }
プロジェクトをビルドして、コンパイル エラーがないことを確認します。
やってみる。
$ vimr Startup.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.HttpsPolicy;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using RazorPagesMovie.Data; //追加
using Microsoft.EntityFrameworkCore; //追加
namespace RazorPagesMovie
{
public class Startup
{
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}
public IConfiguration Configuration { get; }
// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
services.AddRazorPages();
//追加
services.AddDbContext<RazorPagesMovieContext>(
options => options.UseSqlite( Configuration.GetConnectionString("MovieContext") )
);
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Error");
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthorization();
app.UseEndpoints(endpoints =>
{
endpoints.MapRazorPages();
});
}
}
}
コンパイルしてみる。
# dotnet build
Microsoft (R) Build Engine version 16.6.0+5ff7b0c9e for .NET Core
Copyright (C) Microsoft Corporation. All rights reserved.
Determining projects to restore...
All projects are up-to-date for restore.
RazorPagesMovie -> /Projects/RazorPagesMovie/bin/Debug/netcoreapp3.1/RazorPagesMovie.dll
RazorPagesMovie -> /Projects/RazorPagesMovie/bin/Debug/netcoreapp3.1/RazorPagesMovie.Views.dll
Build succeeded.
0 Warning(s)
0 Error(s)
Time Elapsed 00:00:06.11
通れば成功。
ムービー モデルのスキャフォールディング
このセクションでは、ムービー モデルがスキャフォールディングされます。 つまり、スキャフォールディング ツールにより、ムービー モデルの作成、 読み取り、更新、削除の (CRUD) 操作用のページが生成されます。
スキャフォールディングとはなんだろう。
Scaffolding(スキャフォールディング)とは
Scaffolding(スキャフォールディング)とは、データモデルとなる型を元に、 いわゆるCRUD(Create/Read/Upadate/Delete)と呼ばれる追加、読込、変更、削除を行う画面と そのコードを自動で生成する機能のことです(図1)。 Scaffoldingを和訳すると「足場」という言葉であり、その名のとおり少ない手間でアプリケーションの 「足場」となる大枠の構造を作ることを目的としています。 従って、Scaffoldingは完全なアプリケーションを作るための機能ではない、ということは認識しておく必要があります。
簡単にチェックできるように、自動的にデータベース周辺の操作ページが生成されるらしい。やってみる。
- プロジェクト ディレクトリ ( Program.cs 、Startup.cs 、および .csproj ファイルを含むディレクトリ) で コマンド ウィンドウを開きます。
- スキャフォールディング ツールをインストールします。
dotnet tool install --global dotnet-aspnet-codegenerator
- Windows の場合
- 次のコマンドを実行します。
dotnet aspnet-codegenerator razorpage -m Movie -dc RazorPagesMovieContext -udl -outDir Pages\Movies --referenceScriptLibraries
- macOS および Linux の場合
- 次のコマンドを実行します。
dotnet aspnet-codegenerator razorpage -m Movie -dc RazorPagesMovieContext -udl -outDir Pages/Movies --referenceScriptLibraries dotnet tool install --global dotnet-aspnet-codegenerator
次の表で、ASP.NET Core コード ジェネレーターのパラメーターについて詳しく説明します。
パラメーター 説明 -m
モデルの名前。 -dc
使用する DbContext
クラス。-udl
既定のレイアウトを使用します。 -outDir
ビューを作成するための相対出力フォルダー パス。 --referenceScriptLibraries
[編集] および [作成] ページに _ValidationScriptsPartial
を追加します。次のように、
h
スイッチを使用して、aspnet-codegenerator razorpage
コマンドに関するヘルプを取得します。dotnet aspnet-codegenerator razorpage -h
dotnet-aspnet-codegenerator
をインストールする
# dotnet tool install --global dotnet-aspnet-codegenerator
Tool 'dotnet-aspnet-codegenerator' is already installed.
インストールされていた。実行するが、上記引用元は余分なものが入っていそうだ。
# dotnet aspnet-codegenerator razorpage -m Movie -dc RazorPagesMovieContext -udl -outDir Pages/Movies --referenceScriptLi
braries
Building project ...
Finding the generator 'razorpage'...
Running the generator 'razorpage'...
Attempting to compile the application in memory.
Attempting to figure out the EntityFramework metadata for the model and DbContext: 'Movie'
Added Razor Page : /Pages/Movies/Create.cshtml
Added PageModel : /Pages/Movies/Create.cshtml.cs
Added Razor Page : /Pages/Movies/Edit.cshtml
Added PageModel : /Pages/Movies/Edit.cshtml.cs
Added Razor Page : /Pages/Movies/Details.cshtml
Added PageModel : /Pages/Movies/Details.cshtml.cs
Added Razor Page : /Pages/Movies/Delete.cshtml
Added PageModel : /Pages/Movies/Delete.cshtml.cs
Added Razor Page : /Pages/Movies/Index.cshtml
Added PageModel : /Pages/Movies/Index.cshtml.cs
RunTime 00:00:12.96
出力されたらしい。
最初の移行
dotnet ef
がインストールされていない場合は、グローバルツールとしてインストールします。dotnet tool install --global dotnet-ef
EF Core 用の CLI の詳細については、 .Net CLI の EF Core ツール リファレンス を参照してください。
次の .NET Core CLI コマンドを実行します。
dotnet ef migrations add InitialCreate dotnet ef database update
上記のコマンドで次の警告が生成されます。 “エンティティ型 ‘Movie’ の decimal 列 ‘Price’ に型が指定されていません。 これにより、値が既定の有効桁数と小数点以下桁数に収まらない場合、自動的に切り捨てられます。 ‘HasColumnType()’ を使用してすべての値に適合する SQL server 列の型を明示的に指定します。”
この警告は無視して構いません。後のチュートリアルで修正されます。
移行コマンドによって、最初のデータベース スキーマを作成するコードが生成されます。 このスキーマは、
DbContext
で指定されたモデルに基づきます。InitialCreate
引数は移行の命名に使用されます。 任意の名前を使用できますが、規則により、移行を説明する名前が選択されます。
update
コマンドにより、適用されていない移行でUp
メソッドが実行されます。 この場合、update
により、 _Migrations/_InitialCreate.cs_ ファイルで `Up` メソッドが実行され、 データベースが作成されます。
dotnet-ef
はインストールしたはずなのでやってみる。
# dotnet ef migrations add InitialCreate
Build started...
Build succeeded.
Done. To undo this action, use 'ef migrations remove'
# dotnet ef database update
Build started...
Build succeeded.
特に問題なく通った。実行してみる。
# dotnet run
warn: Microsoft.AspNetCore.DataProtection.Repositories.FileSystemXmlRepository[60]
Storing keys in a directory '/root/.aspnet/DataProtection-Keys' that may not be persisted outside of the container. Protected data will be unavailable when container is destroyed.
info: Microsoft.Hosting.Lifetime[0]
Now listening on: http://0.0.0.0:5000
info: Microsoft.Hosting.Lifetime[0]
Now listening on: https://0.0.0.0:5001
info: Microsoft.Hosting.Lifetime[0]
Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
Hosting environment: Development
info: Microsoft.Hosting.Lifetime[0]
Content root path: /Projects/RazorPagesMovie
問題なく動作したらしい。アクセスしてみる。
エラーが出て表示されない。 長くなったのでこの修正は次回にする。