日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

.net core使用数据库

發布時間:2025/3/21 数据库 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 .net core使用数据库 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

.net core使用數據庫

.net core 通過可以通過ef core或其它ORM框架進行數據訪問。此處使用EF和Dapper作為示例。

使用EF Core訪問數據庫

與 .NET Framework訪問數據庫一直,我們可以使用Code-First進行開發,也可以使用DB-First進行開發。我們不關心是現有數據庫還是現有代碼,我們關心如何進行訪問。

首先創建數據模型Model:

[Table("tbl_user")] public class UserEntity {[Column("id")]public int Id { get; set; }[Column("code")]public string Code { get; set; }[Column("name")]public string Name { get; set; }[Column("status")]public UserStatus Status { get; set; } }public enum UserStatus {Enable = 1,Disable = 2, }

然后創建我們的DBContext:

public class DemoDBContext : DbContext {public DbSet<UserEntity> Users { get; set; }protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder){optionsBuilder.UseNpgsql("server=127.0.0.1;userid=postgres;password=123;database=demo;Pooling=false;Enlist=true");base.OnConfiguring(optionsBuilder);}}

使用postgresql數據庫。

在程序中,我們使用new關鍵字創建DbContext對象:

var dbContext = new DemoDBContext(); var user = new UserEntity() {Code = "01",Name = "Tom",Status = UserStatus.Enable };dbContext.Add(user); dbContext.SaveChanges(); Console.WriteLine("User = " + JsonConvert.SerializeObject(user, Formatting.Indented));

此處演示了正常插入數據庫的操作。

使用Dapper訪問數據

Dapper是一個輕量級的ORM框架,性能也很好,唯一的缺點是需要寫大量的SQL腳本。我們來看一下如何使用Dapper進行數據訪問的。

/// <summary> /// 使用Dapper訪問數據庫 /// </summary> public static void UseDapperAccessDatabase() {using (IDbConnection db = OpenConnection("server=127.0.0.1;userid=postgres;password=123;database=demo;Pooling=false;Enlist=true")){var jerry = new UserEntity(){Code = "02",Name = "Jerry",Status = UserStatus.Enable,};jerry.Id = (int)db.Insert(jerry);var user = db.Get<UserEntity>(1);Console.WriteLine($"User = {JsonConvert.SerializeObject(user)}");user = db.QuerySingleOrDefault("select * from tbl_user where id=@id", new { id = 2 });Console.WriteLine($"User = {JsonConvert.SerializeObject(user)}");} }/// <summary> /// get the db connection /// </summary> /// <param name="connectionString"></param> /// <returns></returns> public static IDbConnection OpenConnection(string connectionString) {var conn = new NpgsqlConnection(connectionString);conn.Open();return conn; }

Dapper不支持數據庫列的映射,也就是說,如果數據庫列名和Model的列名不一致時,好像沒有辦法進行處理。

以上代碼僅供演示。

轉載于:https://www.cnblogs.com/youring2/p/9442611.html

總結

以上是生活随笔為你收集整理的.net core使用数据库的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。