Возможные способы создания общей функции вставки данных для всего проекта в asp.net с использованием шаблона репозитория - PullRequest
0 голосов
/ 30 мая 2019

Мне интересно, как я могу избежать записи cmd.Parameter.addwithvalue снова и снова для всех страниц. Короче говоря, что-то вроде универсальной функции вставки. Я не использую Entity Framework, поэтому обычная общая функция добавления сущностей не поможет.

До сих пор я пробовал:

public string AddCampus(Campus objCampus)
    {
                //string Params = "@Activity,@Name,@PhoneNo,@Email,@Logo,@StatusId,@CountryId,@CityId,@StateId,@DistrictId,@ClientId,@Pincode,@AddressLine1,@AddressLine2,@Area,@Street";
                //string Values = "Add" + ',' + objCampus.Name + ',' + objCampus.PhoneNo + ',' + objCampus.Email + ',' + objCampus.Logo + "," + objCampus.StatusId + ","+objCampus.CampusAddress.CountryId + "," + objCampus.CampusAddress.CityId + "," + objCampus.CampusAddress.StateId + "," + objCampus.CampusAddress.DistrictId + "," + objCampus.ClientId + "," + objCampus.CampusAddress.Pincode + "," + objCampus.CampusAddress.AddressLine1 + "," + objCampus.CampusAddress.AddressLine2 + "," + objCampus.CampusAddress.Area + "," + objCampus.CampusAddress.Streat;
                //return  Connection.CommandExecuteNonQuery(Params, Values,true, "sprCampus");
    }

Я сделал это, и это работает, но я только что прокомментировал это. Это была реализация:

   public static string CommandExecuteNonQuery(string Parameters,string Values,bool IsStoredProcedure,string command)
    {   string[] Parameter = Parameters.Split(',');
        string[] Value = Values.Split(',');
        string s_Message = "";
        if (Parameter.Count() < Value.Count())
        {
            s_Message = "Number of Paramters Supplied is less than Number of Values Supplied.";
            return s_Message;
        }
        else if (Parameter.Count() > Value.Count())
        {
            s_Message = "Number of Values Supplied is less than Number of Parameters Supplied.";
            return s_Message;
        }
        else
        {
            SqlCommand cmd = new SqlCommand();
            for (var i = 0; i < Parameter.Count(); i++)
            {
                cmd.Parameters.AddWithValue(Parameter[i], Value[i]);

            }
            cmd.CommandText = command;
            if (IsStoredProcedure)
                cmd.CommandType = CommandType.StoredProcedure;
            string saveSuccess = string.Empty;
            int execute = 0;
            using (SqlConnection con = new SqlConnection(sqlConStr))
            {
                try
                {
                    con.Open();
                    cmd.Connection = con;
                    execute = cmd.ExecuteNonQuery();
                    if (execute > 0)
                    {
                        s_Message = "Record Saved";
                    }
                    else
                        s_Message = "Operation Failed";



                }
                catch (Exception excp)
                {
                    s_Message = excp.Message;
                }

            }
        }
            return s_Message.ToString();







    }

Так что я просто ищу лучшее решение, чем это.

1 Ответ

1 голос
/ 30 мая 2019

У меня была та же идея некоторое время назад. Следующее, вероятно, не самое оптимизированное решение, но я думаю, что оно довольно хорошее.

    // Parameter used for StoredProcedure
    private class Parameter
    {
        public Parameter(string name, object value)
        {
            Name = name;
            Value = value;
        }

        public readonly string Name;
        public readonly object Value;
    }

    // Executes a given stored procedure with parameters and returns a SQLDataReader
    private static SqlDataReader ExecuteDataReader(string name, SqlConnection dbConnection, List<Parameter> parameters = null)
    {
        if (parameters == null)
            parameters = new List<Parameter>();

        using (var command = new SqlCommand(name, dbConnection) { CommandType = CommandType.StoredProcedure })
        {
            foreach (var parameter in parameters)
                command.Parameters.AddWithValue(parameter.Name, parameter.Value);

            return command.ExecuteReader();
        }
    }

    // Executes a given stored procedure with parameters
    private static void ExecuteNonQuery(string name, SqlConnection dbConnection, List<Parameter> parameters = null)
    {
        if (parameters == null)
            parameters = new List<Parameter>();

        using (var command = new SqlCommand(name, dbConnection) { CommandType = CommandType.StoredProcedure })
        {
            foreach (var parameter in parameters)
                command.Parameters.AddWithValue(parameter.Name, parameter.Value);

            command.ExecuteNonQuery();
        }
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...