.NET5控制臺(tái)程序使用EF連接MYSQL數(shù)據(jù)庫的方法
1.使用nuget下載:
Microsoft.Extensions.Configuration.Json
Pomelo.EntityFrameworkCore.MySql
2.數(shù)據(jù)庫中創(chuàng)建好表:
CREATE TABLE `user2` ( `mid` int NOT NULL AUTO_INCREMENT, `uname` varchar(45) NOT NULL, `memo` varchar(200) DEFAULT NULL, PRIMARY KEY (`mid`) ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
3.新建實(shí)體類:
using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; namespace ConsoleApp1 { public class user2 { [Key] //主鍵 [DatabaseGenerated(DatabaseGeneratedOption.Identity)] //設(shè)置自增 public int mid { get; set; } public string uname { get; set; } public string memo { get; set; } } }
4.新建一個(gè)json配置文件:appsettings.json,設(shè)置為始終復(fù)制。
{ "ConnectionStrings": { "Default": "Server=127.0.0.1;Database=wdb;charset=utf8;uid=root;pwd=some;" } }
5.新建DbContext
using Microsoft.EntityFrameworkCore; using Microsoft.Extensions.Configuration; using System.IO; namespace ConsoleApp1 { public class DefaultDbContext : DbContext { private IConfiguration configuration; public DefaultDbContext() { configuration = new ConfigurationBuilder().SetBasePath(Directory.GetCurrentDirectory()).AddJsonFile("appsettings.json").Build(); } public DbSet<user2> user2 { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { string connStr = configuration.GetConnectionString("Default"); optionsBuilder.UseMySql(connStr, ServerVersion.AutoDetect(connStr),null); } } }
6.使用
using ConsoleApp1; using System; using System.Linq; namespace Net5ConsoleMySql { class Program { static void Main(string[] args) { try { DefaultDbContext context = new DefaultDbContext(); Random rnd = new Random(); string i = rnd.Next(1000, 9000).ToString(); user2 zhangsan = new user2 { uname = "張三" + i, memo = i }; user2 lisi = new user2 { uname = "李四" + i, memo = i }; context.user2.AddRange(zhangsan, lisi); context.SaveChanges(); var users = context.user2.ToList(); foreach (var user in users) { Console.WriteLine($"{user.mid} {user.uname} {user.memo}"); } } catch (Exception ex) { Console.WriteLine($"EX: {ex.Message} "); if (ex.InnerException != null) { Console.WriteLine($"INNER EX: {ex.InnerException.Message} "); } } Console.WriteLine("Hello World!"); } } }
到此這篇關(guān)于.NET5控制臺(tái)程序使用EF連接MYSQL數(shù)據(jù)庫的方法的文章就介紹到這了,更多相關(guān).NET5使用EF連接MYSQL內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ASP.NET?Core中間件實(shí)現(xiàn)限流的代碼
這篇文章主要介紹了ASP.NET?Core中間件實(shí)現(xiàn)限流的方法,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03ASP.NET性能優(yōu)化之構(gòu)建自定義文件緩存
ASP.NET的輸出緩存(即靜態(tài)HTML)在.NET4.0前一直是基于內(nèi)存的。這意味著如果我們的站點(diǎn)含有大量的緩存,則很容易消耗掉本機(jī)內(nèi)存。2011-09-09在asp.net中使用加密數(shù)據(jù)庫聯(lián)接字符串保證數(shù)據(jù)安全
加密web.config可以有效保證數(shù)據(jù)庫用戶和密碼安全,下面是示例代碼,大家可以看看2014-09-09asp.net實(shí)現(xiàn)C#繪制太極圖的方法
這篇文章主要介紹了asp.net實(shí)現(xiàn)C#繪制太極圖的方法,實(shí)例分析了asp.net繪制圖形的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02DotNet OnPreRender(EventArgs e) 事件常用的方法
DotNet OnPreRender(EventArgs e) 事件常用的方法,需要的朋友可以參考下。2011-07-07Visual Studio 2015 配置 Opencv3.2的圖文詳解
這篇文章主要介紹了Visual Studio 2015 配置 Opencv3.2的圖文詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05創(chuàng)建一個(gè)ASP.NET MVC5項(xiàng)目的實(shí)現(xiàn)方法(圖文)
這篇文章主要介紹了創(chuàng)建一個(gè)ASP.NET MVC 5項(xiàng)目,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09解析ABP框架中的數(shù)據(jù)傳輸對(duì)象與應(yīng)用服務(wù)
ABP框架是基于ASP.NET的Web開發(fā)框架,在ABP中應(yīng)用服務(wù)將領(lǐng)域邏輯暴露給展現(xiàn)層,展現(xiàn)層通過傳入數(shù)據(jù)傳輸對(duì)象參數(shù)來調(diào)用應(yīng)用服務(wù),而這里我們就來解析ABP框架中的數(shù)據(jù)傳輸對(duì)象與應(yīng)用服務(wù)2016-06-06