ASP.NET MVC 5 не обновляет строки таблицы и не отправляет данные (с таблицами данных) - PullRequest
1 голос
/ 08 мая 2019

Я хочу обновить строки данных и отправить их.Но не обновляйте, потому что мои данные строки отправляют нуль. Как отправить, я выбираю строку, обновляю строку и отправляю.

 @model List<ASTek.Models.CustomersModel>
    @{
    ViewBag.Title = "Customers";
    Layout = "~/Views/Shared/_Layout.cshtml";
    }
     @using (Html.BeginForm("TopluSms", "Mobil", FormMethod.Post))
    {
    @Html.AntiForgeryToken()
    <table class="table table-striped table-bordered table-responsive" id="tblCustomer" style="font-size:11px; position:center">
        <thead>
            <tr style="background-color:#8c7fcf">
                <th>Müşteri</th>
                <th>Telefon</th>
                <th>Bakiye</th>
                <th></th>
                <th></th>
                <th></th>
            </tr>
        </thead>
        <tbody>
            @foreach (var item in Model)
            {
                <tr>
                    <td>@Html.DisplayFor(modelItem => item.FirmaName)</td>                  
                    <td>@Html.TextBoxFor(modelItem => item.TLF)</td>
                    <td> @Html.EditorFor(modelItem => item.Bakiye)</td>
                    <td> @Html.DisplayFor(modelItem => item.LOGICALREF)</td>
                    <td>
                        @Html.CheckBoxFor(modelItem => item.IHTAR, new { style = "width:18px;height:18px;" })
                    </td>
                    <td>
                        <input id="@item.LOGICALREF" type="submit" value="Update" class="btn btn-info" />
                    </td>
                </tr>
            }
        <tbody>
    </table>
}

эта страница просмотра и мой контроллер.Имя таблицы переменных моей базы данных, и я должен использовать его следующим образом: SQL,

 [HttpPost]
    public ActionResult TopluSms(CustomersModel model)
    {
        string LOGICALREF = model.LOGICALREF;
        string TLF = model.TLF;
        string active = "0";
        CustomersModel items = new CustomersModel();
        string a = User.Identity.Name;
        HomeController.sqlconnection con = new HomeController.sqlconnection();
        string firmsec = "UPDATE dbo.LG_005_CLCARD  SET TELNRS1='" + TLF + "',WARNFAXNR='" + active + "' where LOGICALREF=" + LOGICALREF + "";
        SqlCommand cmd = new SqlCommand(firmsec, con.connect());
        cmd.ExecuteNonQuery();
        con.connect().Close();
        return RedirectToAction("TopluSms");

    }

Мой список выбора контроллера и отправка данных.

 [HttpGet]
    public ActionResult TopluSms()
    {
        string aa = User.Identity.Name;
        HomeController.sqlconnection con = new HomeController.sqlconnection();
        string FIRMA = "select t.FIRMA,t.donem FROM dbo.TBLFRM as t where T.USERNAME='" + aa + "'";
        SqlCommand cmd = new SqlCommand(FIRMA, con.connect());
        SqlDataReader rdrr = cmd.ExecuteReader();
        rdrr.Read();
        string firma = rdrr["FIRMA"].ToString();
        string donem = rdrr["DONEM"].ToString();
        string Musteriler = "SELECT CLCARD.LOGICALREF, CLCARD.DEFINITION_ AS  UNVANI,CLCARD.TELNRS1, CAST((SUM((1 - CLFLINE.SIGN) * CLFLINE.AMOUNT) - SUM(CLFLINE.SIGN * CLFLINE.AMOUNT)) as DECIMAL(15, 2)) AS[BAKIYE],CLCARD.WARNFAXNR AS IHTAR " +
            "FROM dbo.LG_" + firma + "_" + donem + "_CLFLINE as CLFLINE INNER JOIN dbo.LG_" + firma + "_CLCARD as CLCARD ON CLFLINE.CLIENTREF = CLCARD.LOGICALREF AND CLFLINE.CANCELLED = 0 " +
            "GROUP BY CLCARD.LOGICALREF, CLCARD.CODE, CLCARD.DEFINITION_, CLCARD.ACTIVE, CLCARD.CITY, CLCARD.CAPIBLOCK_CREADEDDATE ,CLCARD.TELNRS1,CLCARD.WARNFAXNR " +
            "HAVING(CLCARD.CODE LIKE '%') and(CLCARD.DEFINITION_ LIKE '%') AND(CLCARD.ACTIVE = 0) " +
            "ORDER BY CLCARD.DEFINITION_ DESC ";
        // var model = new List<CustomersModel>();
        List<CustomersModel> items = new List<CustomersModel>();
        using (SqlCommand cmdd = new SqlCommand(Musteriler, con.connect()))
        {
            //con.connect().Open();
            SqlDataReader rdr = cmdd.ExecuteReader();

            while (rdr.Read())
            {

                var musteri = new CustomersModel();
                musteri.LOGICALREF = rdr[0].ToString();
                musteri.FirmaName = rdr[1].ToString();
                ViewBag.bakiye = rdr[3].ToString();
                musteri.TLF = rdr[2].ToString();
                musteri.Bakiye = rdr[3].ToString();
                if (rdr[4].ToString() == "1") { musteri.IHTAR = true; }
                else { musteri.IHTAR = false; }
                if (Convert.ToDouble(musteri.Bakiye) > 0)
                {
                    musteri.SIGN = "0";
                }
                else
                {
                    musteri.SIGN = "1";
                }
                items.Add(musteri);

            }
            con.connect().Close();
            return View(items);
        }
    }

Я хочу обновить строку данных

1 Ответ

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

Вы отправляете туда List моделей, но ваш Action TopluSms предназначен для одной модели.Однако, если вы измените parameter вашей функции на List<CustomersModel> models, это может сработать, но это ненадлежащий способ сделать подобные вещи.

Попробуйте использовать любую инфраструктуру управления сеткой внешнего интерфейса, такую ​​как KendoUI , JQGrid и т. Д.

Прочтите там документацию и внедрите.Они используют ajax для CRUD.

и пытаются использовать любой Design Pattern для своего кода бэкенда.

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