.NET5控制台程序使用EF连接MYSQL数据库的方法

作者:runliuv 时间:2024-01-25 08:07:43 

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

来源:https://www.cnblogs.com/runliuv/p/15107430.html

标签:.NET5,EF,MYSQL
0
投稿

猜你喜欢

  • flask框架单元测试原理与用法实例分析

    2021-10-06 04:11:12
  • SQL Server之SELECT INTO 和 INSERT INTO SELECT案例详解

    2024-01-22 01:11:56
  • 清理Mysql general_log的方法总结

    2024-01-14 10:54:34
  • DataReader深入解析:持续更新

    2023-07-11 06:24:08
  • python 判断参数为Nonetype类型或空的实例

    2021-03-21 07:15:17
  • django 做 migrate 时 表已存在的处理方法

    2022-02-14 16:11:53
  • JavaScript实现的背景自动变色代码

    2024-04-16 09:02:17
  • Python获取当前公网ip并自动断开宽带连接实例代码

    2021-08-28 12:40:27
  • MySQL中的多表联合查询功能操作

    2024-01-21 07:21:30
  • python实现五子棋双人对弈

    2023-11-14 05:36:10
  • 微信小程序实现登录注册tab切换效果

    2024-04-29 13:11:29
  • ASP实例:使用ASP生成图片彩色校验码

    2009-01-20 16:27:00
  • SQL SERVER 2012新增函数之逻辑函数IIF

    2024-01-16 05:39:46
  • tensorflow-gpu安装的常见问题及解决方案

    2021-08-18 11:31:18
  • python常规方法实现数组的全排列

    2021-11-20 23:09:29
  • Yii开启片段缓存的方法

    2023-11-21 05:00:40
  • MySQL数据库改名的详细方法教程

    2024-01-18 11:46:27
  • function.inc.php超越php

    2024-06-05 09:22:40
  • display:inline-block的深入理解

    2007-05-11 17:03:00
  • Git远程仓库配置SSH的实现(以github为例)

    2023-10-21 18:16:00
  • asp之家 网络编程 m.aspxhome.com