получить запись из базы данных [SQL] при установленном флажке Asp.Net MVC4 - PullRequest
0 голосов
/ 26 сентября 2018

Я пытаюсь отправить электронное письмо выбранному пользователю.У меня есть пример списка пользователей с флажком, То, что я хочу: Когда один пользователь отмечен и нажата кнопка «Отправить электронную почту», письма отправляются заинтересованному лицу, а если выбран несколько пользователей или установлен флажокщелкает, тогда электронная почта идет всем выбранным пользователям. Адрес электронной почты будет выбран из базы данных для выбранного идентификатора пользователя.

Ниже приведен код, который я пробовал до сих пор, но я запутался ине в состоянии понять это, я новичок в Asp.Net + MVC 4, любая помощь будет оценена.

My Model Code:

public void GetEmails(Employee data)
        {
            SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["mvc"].ConnectionString);
            string qry = "select Email from users where Id IN(@id)";
            SqlCommand cmd = new SqlCommand(qry, con);
            con.Open();

            cmd.Parameters.AddWithValue("@id", data.IsChecked);
            cmd.ExecuteNonQuery();
            con.Close();
        }

My Controller Code:



public ActionResult Employee()  // Get Employee / Student Details
        {
            Employee emp = new Employee();

            List<Employee> students = emp.GetEE();

            return View(students);
        }

        [HttpPost]
        public ActionResult Employee(Employee data)  // Get Employee / Student Emails
        {
            Employee emp = new Employee();

            emp.GetEmails(data);

            return RedirectToAction("Employee");
        }

My View Code:

    @model List<mvcdemo.Models.Employee>
@{
    ViewBag.Title = "Employee";
    Layout = "~/Views/Shared/_Layout.cshtml";
}
<script language="JavaScript">
    function toggle(source) {
        checkboxes = document.getElementsByName('data');
        for (var i = 0, n = checkboxes.length; i < n; i++) {
            checkboxes[i].checked = source.checked;
        }
    }
</script>
<h2>Employee</h2>

<h3>List of Employees</h3>
@Html.BeginForm()
{

<table class="table table-responsive table-responsive">
    <tr>

        <th>First Name</th>
        <th>Last Name</th>
        <th>User Name</th>
        <th>Email Name</th>
        <th>Actions</th>
        <th>Check All <input type="checkbox" name="checkall" onclick="toggle(this)" /></th>
    </tr>
    @foreach (var s in Model)
    {
    <tr>
        <td>@Html.CheckBoxFor(model => s.IsChecked, new { value=@s.Id, id="data" })</td>
        <td>@s.FName</td>
        <td>@s.LName</td>
        <td>@s.UName</td>
        <td>@s.Email</td>
        <td>@Html.ActionLink("Detail", "Details", "Home", new {id=@s.Id },null) / @Html.ActionLink("Edit", "Edit", "Home", new { id = @s.Id }, null) / @Html.ActionLink("Delete", "Delete", "Home", new { id = @s.Id }, null)</td>
       <td id="list"><input type="checkbox" name="data[]" id="data[]" value="@s.Id" /></td>
    </tr>
    }
    <tr>

        <td><button class="btn btn-primary" type="submit">Send Email</button></td>
    </tr>
</table>

}

1 Ответ

0 голосов
/ 04 октября 2018

Попробуйте выполнить следующее:

Контроллер

public ActionResult Index()
        {
            //Generate random and bogus employees
            //Using NBuilder and Faker.Net nuget packages

            var employess = Builder<Employee>.CreateListOfSize(5)
            .All()
            .With(c => c.FName = Faker.Name.First())
            .With(c => c.LName = Faker.Name.Last())
            .With(c => c.UName = Faker.Internet.UserName())
                        .With(c => c.Email = Faker.Internet.Email())
            .With(c => c.IsChecked = Faker.RandomNumber.Next() % 2 == 0)
            .Build();
            return View(employess);
        }

        [HttpPost]
        public ActionResult Employee(IEnumerable<Employee> model)  // Get Employee / Student Emails
        {
            foreach (Employee emp in model)
            {
                if(!emp.IsChecked)
                {
                    continue;
                }
                emp.GetEmails();
            }

            return RedirectToAction("Index");
        }

Код модели

namespace mvcdemo.Models
{
    public class Employee
    {
        public int Id { get; set; }
        public string FName { get; set; }
        public string LName { get; set; }
        public string UName { get; set; }
        public string Email { get; set; }
        public bool IsChecked { get; set; }

        public string EmailContent { get; set; }

        //This is not really a place to have such a method
        internal void GetEmails()
        {
            EmailContent = string.Format("{0}-{1}", FName, LName);
            //SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["mvc"].ConnectionString);
            //string qry = "select Email from users where Id IN(@id)";
            //SqlCommand cmd = new SqlCommand(qry, con);
            //con.Open();

            //cmd.Parameters.AddWithValue("@id", data.IsChecked);
            //cmd.ExecuteNonQuery();
            //con.Close();
        }
    }
}

Просмотреть код

@model List<mvcdemo.Models.Employee>
@{
    ViewBag.Title = "Home Page";
}


<script language="JavaScript">
    function toggle(source) {
        checkboxes = document.querySelectorAll('#data');
        for (var i = 0, n = checkboxes.length; i < n; i++) {
            checkboxes[i].checked = source.checked;
        }
    }
</script>
<h2>Employee</h2>

<h3>List of Employees</h3>

@using (Html.BeginForm("Employee", "Home", FormMethod.Post))

{
    <table class="table table-responsive table-responsive">
        <tr>

            <th>First Name</th>
            <th>Last Name</th>
            <th>User Name</th>
            <th>Email Name</th>
            <th id="checkall">Check All <input type="checkbox" name="checkall" onclick="toggle(this)" /></th>
            <th>Actions</th>

        </tr>
        @{

            for (var i = 0; i < Model.Count; i++)
            {
                <tr>
                    @Html.HiddenFor(model => Model[i].Id)
                    <td>
                        @Html.EditorFor(o => Model[i].FName)
                    </td>
                    <td>@Html.EditorFor(o => Model[i].LName)</td>
                    <td>@Html.EditorFor(o => Model[i].UName)</td>
                    <td>@Html.EditorFor(o => Model[i].Email)</td>
                    <td>@Html.CheckBoxFor(model => Model[i].IsChecked, new { value = Model[i].Id, id = "data" })</td>
                    <td>@Html.ActionLink("Detail", "Details", "Home", new { id = Model[i].Id }, null) / @Html.ActionLink("Edit", "Edit", "Home", new { id = Model[i].Id }, null) / @Html.ActionLink("Delete", "Delete", "Home", new { id = Model[i].Id }, null)</td>

                </tr>
            }
        }

        <tr>

            <td><button class="btn btn-primary" type="submit">Send Email</button></td>
        </tr>
    </table>
}
...