Модели MVC3 без строк подключения Web.Config - PullRequest
3 голосов
/ 11 января 2012

Я работаю над проектом MVC3, где мы разрабатываем один сайт для использования несколькими компаниями. У каждой компании есть свой каталог баз данных. Информация для входа в систему сайта хранится в одной базе данных «Master», и эта база данных содержит имя каталога для каждого пользователя. Но эти каталоги немного отличаются друг от друга по структуре. Я пытаюсь настроить стандартные модели, но привязать данные к этим моделям по-разному в зависимости от каталога для пользователя.

public class UserSearchEntityLayer
{
    public class SearchOptionsList
    {
        public virtual string SearchOptionText { get; set; }
        public virtual string SearchOptionValue { get; set; }
    }
}


public class UserSearchDBLayer : UserSearchEntityLayer
{
    DbSet<SearchOptionsList> SearchOptions { get; set; }

    public UserSearchDBLayer(string ClientCode)
    {
        //Connection Strings
        var ClientConn = "Data Source=HelloWorld;Initial Catalog=" + ClientCode + ";Integrated Security=True;Persist Security Info=True";

        //Prep Work
        DataSet SearchOptionsDS = new DataSet();
        SqlConnection cn = null;
        SqlDataAdapter cmd = null;
        SqlDataReader dr = null;
        string SQLSelect = string.Empty;

        //Start Work
        try
        {
            cn = new SqlConnection(ClientConn);
            cn.Open();
            switch (ClientCode)
            {
                case "AAG":
                    //SearchOptions
                    SQLSelect = "SELECT [Report_Level] as 'Value',[Report_Level_Name] as 'Text' FROM [MASTER_REPORTING_LEVELS] Order By 'Value' DESC";
                    cmd = new SqlDataAdapter(SQLSelect, cn);
                    cmd.Fill(SearchOptionsDS);
                    if (SearchOptionsDS.Tables.Count != 0)
                    {
                        if (SearchOptionsDS.Tables[0].Rows.Count > 0)
                        {
                            foreach (DataRow R in SearchOptionsDS.Tables[0].Rows)
                            {
                                SearchOptions.Add(new SearchOptionsList { SearchOptionText = R["Text"].ToString(), SearchOptionValue = R["Value"].ToString() });
                            }
                        }
                    }
                    SQLSelect = string.Empty;
                    SearchOptionsDS.Dispose();
                    cmd.Dispose();
                    break;
                default:
                    //Do more stuff here
                    break;
            }
        }
        catch 
        {
        }
        finally
        {
    SearchOptions.Add(new SearchOptionsList { SearchOptionText = "States", SearchOptionValue = "States" });
            SearchOptions.Add(new SearchOptionsList { SearchOptionText = "Locations", SearchOptionValue = "Locations" });
            SearchOptions.Add(new SearchOptionsList { SearchOptionText = "Levels", SearchOptionValue = "Levels" });
            SearchOptions.Add(new SearchOptionsList { SearchOptionText = "Name", SearchOptionValue = "Name" });
            if ((dr != null))
            {
                if (!dr.IsClosed)
                    dr.Close();
                dr = null;
            }
            if (cn != null)
            {
                if (cn.State != System.Data.ConnectionState.Closed)
                    cn.Close();
                cn.Dispose();
                cn = null;
            }
            if (cmd != null)
            {
                cmd.Dispose();
                cmd = null;
            }
            if (SQLSelect != null)
                SQLSelect = null;
        }
    }
}

Каков наилучший способ сделать это? О, и прямо сейчас это вызывает ошибку Object, потому что SearchOptions имеет значение null, потому что в нем нет ничего, что я тоже мог бы добавить ...

1 Ответ

1 голос
/ 12 января 2012

Наконец-то все заработало ... Вот мое решение (может быть, оно не очень красивое, но оно работает).

    public class UserSearchDBLayer : UserSearchEntityLayer
{
    public IEnumerable<SearchOptionsList> SearchOptions { get; set; }

    public UserSearchDBLayer(string ClientCode)
    {
        //Connection Strings
        var ClientConn = "Data Source=HelloWorld;Initial Catalog=" + ClientCode + ";Integrated Security=True;Persist Security Info=True";

        //Prep Work
        DataSet SearchOptionsDS = new DataSet();
        SqlConnection cn = null;
        SqlDataAdapter cmd = null;
        SqlDataReader dr = null;
        string SQLSelect = string.Empty;
        //Start Work
        var DataBuilderList = new List<SearchOptionsList>();
        try
        {
            cn = new SqlConnection(ClientConn);
            cn.Open();
            switch (ClientCode)
            {
                case "AAG":
                    //SearchOptions
                    SQLSelect = "SELECT [Report_Level] as 'Value',[Report_Level_Name] as 'Text' FROM [MASTER_REPORTING_LEVELS] Order By 'Value' DESC";
                    cmd = new SqlDataAdapter(SQLSelect, cn);
                    cmd.Fill(SearchOptionsDS);
                    DataBuilderList.Add(new SearchOptionsList { SearchOptionText = "Region", SearchOptionValue = "0" });
                    if (SearchOptionsDS.Tables.Count != 0)
                    {
                        if (SearchOptionsDS.Tables[0].Rows.Count > 0)
                        {
                            foreach (DataRow R in SearchOptionsDS.Tables[0].Rows)
                            {
                                DataBuilderList.Add(new SearchOptionsList { SearchOptionText = R["Text"].ToString(), SearchOptionValue = R["Value"].ToString() });
                            }
                        }
                    }
                    DataBuilderList.Add(new SearchOptionsList { SearchOptionText = "States", SearchOptionValue = "States" });
                    DataBuilderList.Add(new SearchOptionsList { SearchOptionText = "Locations", SearchOptionValue = "Locations" });
                    DataBuilderList.Add(new SearchOptionsList { SearchOptionText = "Levels", SearchOptionValue = "Levels" });
                    DataBuilderList.Add(new SearchOptionsList { SearchOptionText = "Name", SearchOptionValue = "Name" });
                    SQLSelect = string.Empty;
                    SearchOptionsDS.Dispose();
                    cmd.Dispose();
                    break;
                default:
                    //Cool Stuff
                    break;
            }
        }
        catch
        {
        }
        finally
        {
            SearchOptions = DataBuilderList;
            if ((dr != null))
            {
                if (!dr.IsClosed)
                    dr.Close();
                dr = null;
            }
            if (cn != null)
            {
                if (cn.State != System.Data.ConnectionState.Closed)
                    cn.Close();
                cn.Dispose();
                cn = null;
            }
            if (cmd != null)
            {
                cmd.Dispose();
                cmd = null;
            }
            if (SQLSelect != null)
                SQLSelect = null;
        }
    }
}

Тогда ваш контроллер:

public class TestController : Controller
{
    public UserSearchDBLayer model = new UserSearchDBLayer("AAG");
    //
    // GET: /Test/

    public ActionResult Index()
    {

        return View(model);
    }

}

Окончательно Вид:

@model PlayGround.Models.UserSearchDBLayer

@{
Layout = null;
}

<!DOCTYPE html>

<html>
<head>
<title>Index</title>
</head>
<body>

@Html.ListBox("Test", new SelectList(Model.SearchOptions, "SearchOptionValue", "SearchOptionText"), new { size = "25" })

</body>
</html>

Если у вас есть лучшее решение, у меня все уши ... или глаза в этом случае.

...