.Net Core 3.0 Windows Form + Entity Framework Core + SQLite를 사용하고 싶습니다.
환경
요약하면
.NET Core 3.0에서 Windows Form이 지원되었습니다.
ASP.NET Core에서 EF + SQLite를 할 수 있기 때문에 WinForm + EF + SQLite도 갈 수 있지? 라는 발상입니다.
결론으로서 Core가 아닌 EF와 대략 같은 순서로 할 수 있었으므로 정리하고 있습니다.
이미지가 많아서 비교적 길어졌습니다.
접근
.NET Core Windows Form App 프로젝트 구축
data:image/s3,"s3://crabby-images/e0072/e00725813fc99d7a1727eb82e2adc4b286327bbe" alt=""
Windows Forms App (.NET Core)이라는 꽤 그림
Model, DbContext 등을 별도의 DLL로 정리
data:image/s3,"s3://crabby-images/bd394/bd394e1a09b9f47db70a2ebe20b84df47c5ec32e" alt=""
data:image/s3,"s3://crabby-images/d8335/d8335ede573fd7f7ebf979da4579472ca06d5d2f" alt=""
data:image/s3,"s3://crabby-images/a07f7/a07f77040bfb46e23ada805b00c0599ad5045bbf" alt=""
이런 느낌의 프로젝트 구성입니다.
WinFormCoreAppTest에서 EFCoreTest를 참조 설정합니다.
Entity Framework Core 설치
Nuget에서 설치합니다.
Microsoft.EntityFramework.Core.SQLite
data:image/s3,"s3://crabby-images/9f719/9f7195d0f237e5ebbb3f21760dcfe98b23c04b9b" alt=""
Microsoft.EntityFramework.Core.Tools
data:image/s3,"s3://crabby-images/38007/380079faab10ece728316c86e1d7eca041fd6b2c" alt=""
DLL 측 프로젝트에 다양한 클래스 추가
모델
Product.csnamespace EFCoreTest
{
public class Product
{
[Key]
public string ProductId { get; set; }
public int UnitPrice { get; set; }
public string Name { get; set; }
public Product()
{
ProductId = Guid.NewGuid().ToString();
UnitPrice = 0;
Name = string.Empty;
}
}
}
컨텍스트
SampleDbContext.csnamespace EFCoreTest
{
public class SampleDbContext : DbContext
{
/// <summary>
/// サンプル用DbSet
/// </summary>
public DbSet<Product> Products { get; set; }
public SampleDbContext() : base()
{
}
public SampleDbContext(DbContextOptions options) : base(options)
{
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseSqlite("Data Source=sample.db"); //ここでDBファイルを指定
}
}
}
여기까지 하면 한번 빌드해 둡니다.
Migration 클래스를 만들고 DB 파일을 만듭니다.
명령을 실행합니다.
add-migrations (Migration名)
이런 느낌의 로그가 나옵니다.
data:image/s3,"s3://crabby-images/2dba0/2dba01d309a7438c235cdf6aa7e48b46e3b860fb" alt=""
할 수 있었습니다.
InitialCreate.csnamespace EFCoreTest.Migrations
{
public partial class InitialCreate : Migration
{
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.CreateTable(
name: "Products",
columns: table => new
{
ProductId = table.Column<string>(nullable: false),
UnitPrice = table.Column<int>(nullable: false),
Name = table.Column<string>(nullable: true)
},
constraints: table =>
{
table.PrimaryKey("PK_Products", x => x.ProductId);
});
}
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropTable(
name: "Products");
}
}
}
나중에 Migration을 실제로 반영하므로 다음 명령을 실행합니다.
update-database
data:image/s3,"s3://crabby-images/2ca9a/2ca9a00ede27b6fe4ec5bc3fabf24993b11b6841" alt=""
어라? WinFormCoreAppTest 쪽에 할 수 있었습니까?
뭐 할 수 있으면 무엇이든 좋기 때문에 다음으로 진행합니다.
Windows Form의 UI를 적당하게 만든다
쉽게 컨트롤을 배치하여 화면을 만듭니다.
.NET Core Windows Form에서의 UI 작성은 이번 기사의 취지가 아니기 때문에 은근하게 흘립니다.
data:image/s3,"s3://crabby-images/cb8be/cb8be71e51ffc72f9603edeb3cd4c0c77f4a6f6a" alt=""
data:image/s3,"s3://crabby-images/6675a/6675af5586440073191ac3a99b014aebed8c3f8c" alt=""
디폴트의 아이콘이 약간 세련되고 되어 있다…
CRUD 사용
우선 샘플 데이터를 만들어 둡니다.
이것이 표시되므로 Select는 OK.
data:image/s3,"s3://crabby-images/6ff41/6ff41979b78a4e454a7ece81be2e9afae9d8a6c0" alt=""
우선 Insert
data:image/s3,"s3://crabby-images/08c69/08c69e78e4a8b030d269ecbb0634f81fb58bbeec" alt=""
data:image/s3,"s3://crabby-images/718c1/718c1b0d704479cde29de6452caca81885bbf2ab" alt=""
하단이 추가되었습니다.
다음은 Update
data:image/s3,"s3://crabby-images/c9ae6/c9ae631d8b81b4893d234d21b7c2c4b8e8d0e92f" alt=""
data:image/s3,"s3://crabby-images/2a5d4/2a5d477e4a9d68f61c876f0ca275dcd89f8d45ae" alt=""
Sample2라는 사람이 업데이트되었습니다.
마지막 Delete.
data:image/s3,"s3://crabby-images/4e299/4e299542513870d435a0f3d7754150aa2bf72f35" alt=""
data:image/s3,"s3://crabby-images/d1425/d1425b6b66cd99fb401c115d073edc5b3635cfa3" alt=""
Sample3은 녀석을 삭제했습니다.
CRUD 전부 OK. 훌륭합니다.
요약
.NET Core Windows Form App 프로젝트 구축
data:image/s3,"s3://crabby-images/e0072/e00725813fc99d7a1727eb82e2adc4b286327bbe" alt=""
Windows Forms App (.NET Core)이라는 꽤 그림
Model, DbContext 등을 별도의 DLL로 정리
data:image/s3,"s3://crabby-images/bd394/bd394e1a09b9f47db70a2ebe20b84df47c5ec32e" alt=""
data:image/s3,"s3://crabby-images/d8335/d8335ede573fd7f7ebf979da4579472ca06d5d2f" alt=""
data:image/s3,"s3://crabby-images/a07f7/a07f77040bfb46e23ada805b00c0599ad5045bbf" alt=""
이런 느낌의 프로젝트 구성입니다.
WinFormCoreAppTest에서 EFCoreTest를 참조 설정합니다.
Entity Framework Core 설치
Nuget에서 설치합니다.
Microsoft.EntityFramework.Core.SQLite
data:image/s3,"s3://crabby-images/9f719/9f7195d0f237e5ebbb3f21760dcfe98b23c04b9b" alt=""
Microsoft.EntityFramework.Core.Tools
data:image/s3,"s3://crabby-images/38007/380079faab10ece728316c86e1d7eca041fd6b2c" alt=""
DLL 측 프로젝트에 다양한 클래스 추가
모델
Product.cs
namespace EFCoreTest
{
public class Product
{
[Key]
public string ProductId { get; set; }
public int UnitPrice { get; set; }
public string Name { get; set; }
public Product()
{
ProductId = Guid.NewGuid().ToString();
UnitPrice = 0;
Name = string.Empty;
}
}
}
컨텍스트
SampleDbContext.cs
namespace EFCoreTest
{
public class SampleDbContext : DbContext
{
/// <summary>
/// サンプル用DbSet
/// </summary>
public DbSet<Product> Products { get; set; }
public SampleDbContext() : base()
{
}
public SampleDbContext(DbContextOptions options) : base(options)
{
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseSqlite("Data Source=sample.db"); //ここでDBファイルを指定
}
}
}
여기까지 하면 한번 빌드해 둡니다.
Migration 클래스를 만들고 DB 파일을 만듭니다.
명령을 실행합니다.
add-migrations (Migration名)
이런 느낌의 로그가 나옵니다.
data:image/s3,"s3://crabby-images/2dba0/2dba01d309a7438c235cdf6aa7e48b46e3b860fb" alt=""
할 수 있었습니다.
InitialCreate.cs
namespace EFCoreTest.Migrations
{
public partial class InitialCreate : Migration
{
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.CreateTable(
name: "Products",
columns: table => new
{
ProductId = table.Column<string>(nullable: false),
UnitPrice = table.Column<int>(nullable: false),
Name = table.Column<string>(nullable: true)
},
constraints: table =>
{
table.PrimaryKey("PK_Products", x => x.ProductId);
});
}
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropTable(
name: "Products");
}
}
}
나중에 Migration을 실제로 반영하므로 다음 명령을 실행합니다.
update-database
data:image/s3,"s3://crabby-images/2ca9a/2ca9a00ede27b6fe4ec5bc3fabf24993b11b6841" alt=""
어라? WinFormCoreAppTest 쪽에 할 수 있었습니까?
뭐 할 수 있으면 무엇이든 좋기 때문에 다음으로 진행합니다.
Windows Form의 UI를 적당하게 만든다
쉽게 컨트롤을 배치하여 화면을 만듭니다.
.NET Core Windows Form에서의 UI 작성은 이번 기사의 취지가 아니기 때문에 은근하게 흘립니다.
data:image/s3,"s3://crabby-images/cb8be/cb8be71e51ffc72f9603edeb3cd4c0c77f4a6f6a" alt=""
data:image/s3,"s3://crabby-images/6675a/6675af5586440073191ac3a99b014aebed8c3f8c" alt=""
디폴트의 아이콘이 약간 세련되고 되어 있다…
CRUD 사용
우선 샘플 데이터를 만들어 둡니다.
이것이 표시되므로 Select는 OK.
data:image/s3,"s3://crabby-images/6ff41/6ff41979b78a4e454a7ece81be2e9afae9d8a6c0" alt=""
우선 Insert
data:image/s3,"s3://crabby-images/08c69/08c69e78e4a8b030d269ecbb0634f81fb58bbeec" alt=""
data:image/s3,"s3://crabby-images/718c1/718c1b0d704479cde29de6452caca81885bbf2ab" alt=""
하단이 추가되었습니다.
다음은 Update
data:image/s3,"s3://crabby-images/c9ae6/c9ae631d8b81b4893d234d21b7c2c4b8e8d0e92f" alt=""
data:image/s3,"s3://crabby-images/2a5d4/2a5d477e4a9d68f61c876f0ca275dcd89f8d45ae" alt=""
Sample2라는 사람이 업데이트되었습니다.
마지막 Delete.
data:image/s3,"s3://crabby-images/4e299/4e299542513870d435a0f3d7754150aa2bf72f35" alt=""
data:image/s3,"s3://crabby-images/d1425/d1425b6b66cd99fb401c115d073edc5b3635cfa3" alt=""
Sample3은 녀석을 삭제했습니다.
CRUD 전부 OK. 훌륭합니다.
요약
이상입니다.
Reference
이 문제에 관하여(.Net Core 3.0 Windows Form + Entity Framework Core + SQLite를 사용하고 싶습니다.), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/Poly-P/items/336f4f2006fec0613c7a텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)