.NET5控制台程序使用EF连接MYSQL

1.使用nuget下载:

Microsoft.Extensions.Configuration.Json

Pomelo.EntityFrameworkCore.MySql

2.数据库中创建好表:

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!");
}
}
}

最新文章

  1. AngularJS之高级Route【三】(八)
  2. 给Source Insight做个外挂系列之四--分析“Source Insight”
  3. 海量用户-高并发SAAS产品测试上线流程
  4. c#事件与委托
  5. Backbone.js学习之一
  6. 《无懈可击的Web设计》_灵活的文字
  7. error C2471: 无法更新程序数据库
  8. CAS Spring Security 3 整合配置(转)
  9. windows下用cordova构建android app
  10. 【Python3之面向对象的程序设计】
  11. .NET程序集引用COM组件MSScriptControl所遇到的问题
  12. Java中引用传递
  13. quotes 整站数据爬取存mongo
  14. .NET Core----zipkin链路追踪使用
  15. Winform让扫描枪听话,防止在有焦点的地方就扫码输入的尴尬
  16. LogFilter
  17. 020 Spark中分组后的TopN,以及Spark的优化(重点)
  18. NumPy 切片和索引
  19. 洛谷 P1972 [SDOI2009]HH的项链
  20. 洛谷P2827 蚯蚓 题解

热门文章

  1. ES6学习笔记之字符串新增方法
  2. 关于Word转Markdown的工具Typora安装及使用
  3. .net core 常用rsa 加签类
  4. hdu 2159 二维完全背包
  5. Java实验项目三——宠物商店
  6. XCTF 3rd-GCTF-2017 hackme
  7. cordova自定义插件开发流程
  8. F5节点分配查看
  9. 日志采集工具Flume的安装与使用方法
  10. java课堂动手动脑及课后实验总结