.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
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
flask框架单元测试原理与用法实例分析
2021-10-06 04:11:12
![](https://img.aspxhome.com/file/2023/5/131765_0s.png)
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
![](https://img.aspxhome.com/file/2023/4/136724_0s.png)
Python获取当前公网ip并自动断开宽带连接实例代码
2021-08-28 12:40:27
MySQL中的多表联合查询功能操作
2024-01-21 07:21:30
![](https://img.aspxhome.com/file/2023/9/68049_0s.jpg)
python实现五子棋双人对弈
2023-11-14 05:36:10
![](https://img.aspxhome.com/file/2023/7/114567_0s.jpg)
微信小程序实现登录注册tab切换效果
2024-04-29 13:11:29
![](https://img.aspxhome.com/file/2023/1/132861_0s.jpg)
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
![](https://img.aspxhome.com/file/2023/0/131330_0s.jpg)
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
![](https://img.aspxhome.com/file/2023/4/123744_0s.png)