首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >跨环境管理多个数据库ID

跨环境管理多个数据库ID
EN

Stack Overflow用户
提问于 2021-01-30 23:14:56
回答 1查看 51关注 0票数 0

在工作中,我们为生产和开发环境提供了不同的数据库。这些数据库具有相同的模式,但数据却大相径庭。

我们有多个“行为变量”,在后端,这些变量会导致如下代码

代码语言:javascript
复制
switch(row.ProcessID)
{
    case 1:
        buy();
        break;
    case 2:
        sell();
        break;
}

当然,这里的问题是用于生产的相同代码,例如,应该如下所示

代码语言:javascript
复制
switch(row.ProcessID)
{
    case 2:
        buy();
        break;
    case 8:
        sell();
        break;
}

问题是我如何在开发和生产中处理这些不同的is?

EN

回答 1

Stack Overflow用户

发布于 2021-02-01 14:50:07

您可以通过注入IWebHostEnvironment来使用IsDevelopment()IsProduction()扩展来满足您的需求:

代码语言:javascript
复制
using Microsoft.Extensions.Hosting;
using Microsoft.AspNetCore.Hosting;

public class HomeController : Controller
{
    private readonly IWebHostEnvironment _env;
    public HomeController(IWebHostEnvironment env)
    {
        _env = env;
    }

    public async Task<IActionResult> Index()
    {
        switch (row.ProcessID)
        {
            case 1:
                buy();
                break;

            case 2:
                if (_env.IsDevelopment())
                {
                    sell();
                }
                else
                {
                    buy();
                }
                break;
            case 8:
                sell();
                break;
        }
    }
}

如果使用asp.net Core2.x,则需要使用IHostingEnvironment

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65969605

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档