您好,登錄后才能下訂單哦!
小編給大家分享一下.NET5控制臺程序如何使用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.新建實體類:
using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; namespace ConsoleApp1 { public class user2 { [Key] //主鍵 [DatabaseGenerated(DatabaseGeneratedOption.Identity)] //設置自增 public int mid { get; set; } public string uname { get; set; } public string memo { get; set; } } }
4.新建一個json配置文件:appsettings.json,設置為始終復制。
{ "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!"); } } }
以上是“.NET5控制臺程序如何使用EF連接MYSQL數(shù)據(jù)庫”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。