asp.net core webapi 使用ef 对mysql进行增删改查,并生成Docker镜像构建容器运行
1.构建运行mysql容器,添加数据库user
参考Docker创建运行多个mysql容器,地址 http://www.cnblogs.com/heyangyi/p/9288402.html
添加user数据库,添加tbusers表

2.创建asp.net core webapi 应用程序
参考Docker 为 ASP.NET Core WebApi 应用程序生成 Docker 映像,创建容器并运行,地址 http://www.cnblogs.com/heyangyi/p/9323407.html
<2.1> 修改 appsettings.json 文件,添加 dbconn 数据库链接配置

<2.2> 新增Config类,用来存储配置
public class Config
{
public static string dbconn;
}
<2.3> 修改Program 类,读取配置
public class Program
{
private static IConfigurationRoot Configuration { get; set; } public static void Main(string[] args)
{
var builder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json"); Configuration = builder.Build();
Config.dbconn = Configuration.GetValue<string>("dbconn"); BuildWebHost(args).Run();
} public static IWebHost BuildWebHost(string[] args) =>
WebHost.CreateDefaultBuilder(args)
.UseStartup<Startup>()
.Build();
}
<2.4> 新增DataContext类
安装引用:MySql.Data.EntityFrameworkCore

public class DataContext : DbContext
{
public DbSet<tbuser> tbusers { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) => optionsBuilder.UseMySQL(Config.dbconn);
}
public class tbuser
{
[DatabaseGenerated(DatabaseGeneratedOption.None)]
public int id { get; set; }
public string nickName { get; set; }
public string email { get; set; }
}
<2.5> 新增tbuserDataHandle类
public class tbuserDataHandle : DataContext
{
public static int adduser(tbuser user)
{
try
{
using (var context = new DataContext())
{
context.Database.EnsureCreated();
context.Add(user); context.SaveChanges();
}
return 200;
}
catch (Exception ex)
{
return 300;
}
} public static List<tbuser> Get()
{
try
{
using (var context = new DataContext())
{
var users = context.tbusers;
List<tbuser> items = new List<tbuser>();
foreach (var item in users)
{
items.Add(item);
}
return items;
}
}
catch (Exception ex)
{
return null;
}
} public static tbuser Get(int id)
{
try
{
using (var context = new DataContext())
{
var u = context.tbusers.Find(id);
return u;
}
}
catch (Exception ex)
{
return null;
}
} public static int Delete(int id)
{
try
{
using (var context = new DataContext())
{
var u = context.tbusers.Remove(new tbuser() { id = id });
context.SaveChanges();
return 200;
}
}
catch (Exception ex)
{
return 300;
}
} public static int Put(int id, tbuser user)
{
try
{
using (var context = new DataContext())
{
var u = context.tbusers.Update(user);
context.SaveChanges();
return 200;
}
}
catch (Exception ex)
{
return 300;
}
}
}
<2.6> 新增userController Api
[Produces("application/json")]
[Route("api/user")]
public class userController : Controller
{
// POST api/user
[HttpPost]
public int Post(tbuser user)
{
return tbuserDataHandle.adduser(user);
}
// GET api/user
[HttpGet]
public List<tbuser> Get()
{
return tbuserDataHandle.Get();
}
// GET api/user/5
[HttpGet("{id}")]
public tbuser Get(int id)
{
return tbuserDataHandle.Get(id);
}
// DELETE api/user/5
[HttpDelete("{id}")]
public int Delete(int id)
{
return tbuserDataHandle.Delete(id);
}
// PUT api/user/5
[HttpPut("{id}")]
public int Put(int id, tbuser user)
{
return tbuserDataHandle.Put(id, user);
}
}
3.生成项目,构建docker镜像并创作容器运行
修改 docker-compose.yml ,docker-compose.override.yml 的 version 为:
version: '2.0'
配置 appsettings.json 的 dbconn 为:
"dbconn": "server=192.168.99.100;user id=root;password=123456;persistsecurityinfo=True;port=3307;database=user;SslMode=none"
进入到 E:\web\ilinkcore (这个目录为解决方案的根目录)
docker-compose up

- up 自动完成包括构建镜像,创建服务,启动服务并关联服务容器的一系列操作
执行成功后创建一个 ilinkcore 的镜像,并且运行了一个 ilinkcore_ilinkcore_1的容器,将本机的32783端口映射到容器的80端口


4.测试访问接口
添加反向代理,修改nginx 配置
server{
listen 84;
server_name localhost;
location / {
proxy_pass http://192.168.99.100:32783;
index index.html index.htm;
}
}
重新运行nginx,使用Postman进行api接口测试

<4.1> 测试接口进行添加user数据

Headers 中添加项:
Content-Type:application/json
<4.2>查看所有用户数据

<4.3> 检索某个用户数据

<4.4> 更新某个用户数据

Headers 中添加项:
Content-Type:application/json

<4.5> 删除单个用户


asp.net core webapi 使用ef 对mysql进行增删改查,并生成Docker镜像构建容器运行的更多相关文章
- Asp.Net操作MySql数据库增删改查
Asp.Net操作MySql数据库增删改查,话不多说直接步入正题.git源码地址:https://git.oschina.net/gxiaopan/NetMySql.git 1.安装MySQL数据库 ...
- Java连接MySQL数据库增删改查通用方法
版权声明:本文为博主原创文章,未经博主允许不得转载. Java连接MySQL数据库增删改查通用方法 运行环境:eclipse+MySQL 以前我们Java连接MySQL数据库都是一个数据库写一个类,类 ...
- MySQL数据库(增删改查语句)
MySQL数据库(增删改查语句)一.登录数据库:----> mysql -uroot -proot;(对应用户名和密码)二.SQL语句: 数据定义语言DDL 用来定义数据库.表.列,关 ...
- python操作mysql数据库增删改查的dbutils实例
python操作mysql数据库增删改查的dbutils实例 # 数据库配置文件 # cat gconf.py #encoding=utf-8 import json # json里面的字典不能用单引 ...
- Mysql 的 增删改查
mysql的增删改查 1:新建数据库 create database 数据库名 [其他选项]; 2:新建数据表 create table students ( id int unsigned not ...
- MySQL之增删改查之
MySQL之增删改查 前言:以下是MySQL最基本的增删改查语句,很多IT工作者都必须要会的命令,也是IT行业面试最常考的知识点,由于是入门级基础命令,所有所有操作都建立在单表上,未涉及多表操作. ...
- MySql之增删改查 · YbWork's Studio
前提:在进行"增删改查"的操作之前,先建立一个包含数据表student的数据库(具体操作可以见MySQL之最基本命令): 1."增"--添加数据 1.1 为表中 ...
- 使用MySQL练习增删改查时因为版本问题出现连接错误
使用MySQL练习增删改查时出现连接错误,错误提示如下: 2020-02-19 19:53:51.088 ERROR 16328 --- [reate-249798694] com.alibaba.d ...
- koa+mysql实现增删改查-全栈之路(001)
Date: 2020-4-23 以前很少写文章,从今天开始我要挑战一下自己,连续输出100篇技术类文章.这100篇文章我尽量以实战案例为主. 如果你觉得本文还不错,记得关注或者给个 star,你们的赞 ...
随机推荐
- 缓存中使用的ReentrantReadWriteLock锁
java中提供了lock锁,简便了设计缓存,下面程序主要是使用读写锁的应用.... import java.util.HashMap; import java.util.Map; import jav ...
- 开发 C# OPC 客户端
编写 opc 客户端的思路 1. 使用OPC Client浏览服务器, 查看测试代码修改后的结果. 2. 根据OPC Client搜集到的服务器信息编写代码和服务器交互 3. OPC Client 操 ...
- DotNetCore依赖注入实现批量注入
文章转载自平娃子(QQ:273206491):http://os.pingwazi.cn/resource/batchinjectservice 一.依赖注入 通过依赖注入,可以实现接口与实现类的松耦 ...
- MariaDB 连接查询与子查询(6)
MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可MariaDB的目的是完全兼容MySQL,包括API和命令行,MySQL由于现在闭源了,而能轻松成为MySQ ...
- Python 生成器的使用(yield)
一. 生成器就是一个特殊的迭代器, 使用关键字yield就可以生成一个生成器 def func(): for i in range(10): yield i item = func() yield i ...
- 【TensorFlow】:解决TensorFlow的ImportError: DLL load failed: 动态链接库(DLL)初始化例程失败
[背景] 在scikit-learn基础上系统结合数学和编程的角度学习了机器学习后(我的github:https://github.com/wwcom614/machine-learning),意犹未 ...
- 跟踪spring MVC的请求
当我们点击一个超链接时,spring MVC在后台都做了些什么呢,今天就来看看后台都干了啥 首先需要在web.xml里配置一下:
- idea 安装mybatis plugin (mybatis插件)
注意:可以用免费版本的,就是下面没有 被红框圈中的 Free Mybatis Plugin 安装上以后需要破解,先找到下面的文件 打开文件,设置其中的key 和 value : 这里面的key 和 v ...
- 剑指offer十一之二进制中1的个数
一.题目 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. 二.思路 方法一: 用1(1自身左移运算,其实后来就不是1了)和n的每位进行位与,来判断1的个数 方法二: 把一个整数减去1 ...
- rtp header
rtp协议基于udp传输,流媒体音视频数据被封装在rtp中,通过rtp协议进行实时的传输. 一.rtp协议头格式 The RTP header has a minimum size of 12 byt ...