激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - .net core下配置訪問數據庫操作

.net core下配置訪問數據庫操作

2020-05-25 13:45Bug生活2048 ASP.NET教程

本篇文章給大家詳細分享了在.net core下配置訪問數據庫的相關操作過程以及代碼實現過程,有興趣的朋友參考下。

配置讀取

.net core下讀取配置還是有點麻煩的,本身沒有System.Configuration.dll,所以在進行配置前需要自行引用Microsoft.Extensions.Configuration,截圖如下:

.net core下配置訪問數據庫操作

這樣的話我們就可以配置讀取的相關編碼了,比如我們數據庫的鏈接字符串,在appsettings.json添加對應的數據庫配置:

?
1
2
3
"ConnectionStrings": {
"TestDb": "server=localhost;port=3306;database=mytest;user=test;password=123456;charset=utf8;"
}

讀取配置相關代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
public class AppSetting
{
 private static readonly object objLock = new object();
 private static AppSetting instance = null;
 
 private IConfigurationRoot Config { get; }
 
 private AppSetting()
 {
 var builder = new ConfigurationBuilder()
  .SetBasePath(Directory.GetCurrentDirectory())
  .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true);
 Config = builder.Build();
 }
 
 public static AppSetting GetInstance()
 {
 if (instance == null)
 {
  lock (objLock)
  {
  if (instance == null)
  {
   instance = new AppSetting();
  }
  }
 }
 
 return instance;
 }
 
 public static string GetConfig(string name)
 {
 return GetInstance().Config.GetSection(name).Value;
 }
}

這樣就可以直接讀取對應的配置信息啦:

?
1
string CONNECTION_STRING = AppSetting.GetConfig("ConnectionStrings:TestDb");

數據庫操作

數據庫相關操作還是建議使用Dapper以及Dapper.Contrib,比較輕量,也比較方便。

Dapper相信大家還是比較熟悉的,這里簡單說下Dapper.Contrib,基于Dapper的擴展方法,封裝了如下方法:

  • T Get<T>(id);
  • IEnumerable<T> GetAll<T>();
  • int Insert<T>(T obj);
  • int Insert<T>(Enumerable<T> list);
  • bool Update<T>(T obj);
  • bool Update<T>(Enumerable<T> list);
  • bool Delete<T>(T obj);
  • bool Delete<T>(Enumerable<T> list);
  • bool DeleteAll<T>();

這樣對應你應用的簡單的CRUD方法可以很輕松的搞定的。比如下面幾個例子:

?
1
2
3
4
5
6
//根據主鍵Id查詢
using (var conn = DatabaseManager.GetConnection(DatabaseManager.DBName))
{
 await conn.OpenAsync();
 return await conn.GetAsync<UserModel>(id);
}

新增數據:

?
1
2
3
4
5
6
//新增
using (var conn = DatabaseManager.GetConnection(DatabaseManager.DBName))
{
 await conn.OpenAsync();
 await conn.InsertAsync(entity);
}

修改數據:

?
1
2
3
4
5
6
//修改
using (var conn = DatabaseManager.GetConnection(DatabaseManager.DBName))
{
 await conn.OpenAsync();
 await conn.UpdateAsync(entity);
}

需要注意的是,需要給對應的實體加上特性:

?
1
2
3
4
5
6
7
8
[Table("User")]
public class UserModel
{
 [Key]
 public int Id { get; set; }
 public string UserName { get; set; }
 public string Remark { get; set; }
}
  • [Table("Tablename")] 標識對應的表名
  • [Key] 對應的主鍵
  • [ExplicitKey] 如果主鍵不是自增長的,用此標識
  • [Write(true/false)] 該字段是否可被寫入

原文鏈接:https://segmentfault.com/a/1190000014051679

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久久久久亚洲综合影院红桃 | 狠狠操在线观看 | www.mitao| 日本aaaa片毛片免费观看视频 | 在线天堂中文在线资源网 | 日韩视频精品一区 | 国产精品18久久久久久久 | 国产精选久久久 | 欧美性生交xxxxx久久久缅北 | 久夜草| 久久久久久久免费看 | 免费黄色在线观看网站 | 啪啪激情 | 久久久国产精品成人免费 | 久久精品操 | 久久亚洲国产精品 | 成人18在线 | 久久精品欧美电影 | 久综合 | 国产精品高潮99久久久久久久 | 91成人免费看| 久久久国产精品网站 | 亚洲人成电影在线 | 操嫩草| 中文字幕h | asian裸体佳人pics | 欧美在线电影 | 99国产精品国产免费观看 | a免费视频 | 日韩在线播放中文字幕 | 久久精品免费国产 | 国产一区二区午夜 | 一区二区三区日本在线观看 | 国产日产精品一区二区三区四区 | 国产在线播放一区二区 | 91成人久久 | 欧美亚洲另类在线 | 亚洲成人在线免费 | 日本黄色一级视频 | 广州毛片| av在线播放亚洲 |