一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲人成网站在线观看青青 | 国产高清免费在线 | 免费看美女被靠到爽的视频 | 32pao强力打造免费高速高 | 91精品综合久久久久m3u8 | 亚洲国产果果在线播放在线 | 99热在线观看免费 | 好男人资源在线观看免费的 | 5566中文字幕亚洲精品 | 三级伦理在线播放 | 日韩视频免费一区二区三区 | 亚洲第一天堂无码专区 | 欧美一级高清片免费一级 | 国产日韩欧美在线一区二区三区 | 日本视频在线免费播放 | 日韩理论片在线看免费观看 | 欧美成人一区二区 | 99ri国产精品 | 日韩欧免费一区二区三区 | 国产精品香蕉 | 人妖三级 | 狠狠干在线观看 | 日本春菜花在线中文字幕 | 亚洲精品乱码久久久久久蜜桃 | 好紧水好多| 日本韩国推理片免费观看网站 | 亚洲国内精品久久 | 魔法满屋免费观看完整版中文 | 色久天| 久久爽狠狠添AV激情五月 | 国产精品久久久精品日日 | 波多野结衣不卡 | 护士被多人调教到失禁h | 色老大在线 | 18国产精品白浆在线观看免费 | 香港三级血恋3 | 深夜精品高中女学生 | 欧美在线观看一区二区三 | 亚洲精品久久久992KVTV | 扒开女人屁股眼看个够 | 青青青国产在线观看 |