Вставка нескольких идентификаторов в таблицу SQL из таблицы, которая позволяет выбрать несколько флажков - PullRequest
0 голосов
/ 09 октября 2018

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

Я использовал foreach нараздел aspx, который выглядит нормально, однако при нажатии кнопки ничего не вставляется.

Код Gridview.

<asp:GridView ID="GV_EyeBall" runat="server" AutoGenerateColumns="False" Font-Size="Small" Width="44%" >
    <RowStyle HorizontalAlign="Center" />
    <Columns>
        <asp:BoundField DataField="DataId" HeaderText="DataId" ItemStyle-Width="90px" ItemStyle-Wrap="false" ItemStyle-CssClass="checkIt" SortExpression="DataId" HeaderStyle-CssClass="text-center" />
        <asp:BoundField DataField="BusinessName" HeaderText="BusinessName" ItemStyle-Width="90px" ItemStyle-Wrap="false" ItemStyle-CssClass="checkIt" SortExpression="BusinessName" HeaderStyle-CssClass="text-center" ControlStyle-Font-Size="Small" />
        <asp:BoundField DataField="Industry" HeaderText="Industry" ItemStyle-Width="90px" ItemStyle-Wrap="false" ItemStyle-CssClass="checkIt" SortExpression="Industry" HeaderStyle-CssClass="text-center" />
        <asp:BoundField DataField="TelephoneNumber" HeaderText="TelephoneNumber" ItemStyle-Width="90px" ItemStyle-Wrap="false" ItemStyle-CssClass="checkIt" SortExpression="TelephoneNumber" HeaderStyle-CssClass="text-center" />
        <asp:TemplateField ItemStyle-Width="75px" ItemStyle-Wrap="false">
            <ItemTemplate>
                <asp:CheckBox ID="Removechk" runat="server" ItemStyle-Width="100px" HeaderText="Remove" />
                <%--<asp:HiddenField ID="DataID" runat="server" Value='<%# Eval("DataID") %>' />--%>
            </ItemTemplate>
        </asp:TemplateField>
    </Columns>
    <HeaderStyle BackColor="Silver" ForeColor="Black" />
</asp:GridView>

код страницы aspx

protected void Btnsubmit_Click(object sender, EventArgs e)
{
    string str = string.Empty;
    string strname = string.Empty;
    foreach (GridViewRow gvrow in GV_EyeBall.Rows)
    {
        CheckBox chk = (CheckBox)gvrow.FindControl("Removechk");
        if (chk.Checked)
        {
            Calldatabase.InsertEyeballids(Convert.ToInt32(gvrow.Cells[0].Text));

        }
    }
}

Загрузка страницы

        protected void Page_Load(object sender, EventArgs e)
    {
        var eyeball = Calldatabase.Eyeball();

        GV_EyeBall.DataSource = eyeball;
        GV_EyeBall.DataBind();
    }

1 Ответ

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

Кажется, что ваш вид сетки снова связывается при нажатии кнопки отправки на Page_Load.Поскольку вы не поделились своим методом Page_Load, я реализовал следующий рабочий фрагмент на основе вашей проблемы.

WebForm1.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="tempApp13.WebForm1" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
        <asp:GridView ID="gv" runat="server" AutoGenerateColumns="false">
            <Columns>
                <asp:BoundField DataField="ID" HeaderText="ID" />
                <asp:BoundField DataField="Name" HeaderText="Name" />
                <asp:BoundField DataField="Job" HeaderText="Job" />
                <asp:BoundField DataField="Salary" HeaderText="Salary" />                
                <asp:TemplateField>
                    <ItemTemplate>
                        <asp:CheckBox ID="chkRemove" runat="server" HeaderText="Remove" />                        
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
        </asp:GridView>
        <asp:Button ID="btnSubmit" Text="Submit" runat="server" OnClick="btnSubmit_Click" />
        <asp:Literal ID="litMessage" runat="server" />
    </form>
</body>
</html>

WebForm1.aspx.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace tempApp13
{
    public partial class WebForm1 : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                gv.DataSource = new List<Employee>
                {
                    new Employee { ID = 1, Name = "John", Job = "Clerk", Salary = 25000 },
                    new Employee { ID = 2, Name = "Allen", Job = "Clerk", Salary = 20000 },
                    new Employee { ID = 3, Name = "Smith", Job = "Sales", Salary = 21000 },
                    new Employee { ID = 4, Name = "Martin", Job = "Sales", Salary = 35000 },
                    new Employee { ID = 5, Name = "Bruce", Job = "Analyst", Salary = 35000 },
                    new Employee { ID = 6, Name = "James", Job = "Clerk", Salary = 25000 },
                };
                gv.DataBind();
            }
        }

        protected void btnSubmit_Click(object sender, EventArgs e)
        {
            foreach (GridViewRow row in gv.Rows)
            {
                var chk = (CheckBox)row.FindControl("chkRemove");
                if (chk.Checked)
                {
                    litMessage.Text += row.Cells[1].Text + " ";
                }
            }
        }
    }

    public class Employee
    {
        public int ID { get; set; }
        public string Name { get; set; }
        public string Job { get; set; }
        public int Salary { get; set; }
    }
}

Я взял пример сотрудников источника данных и связал его с представлением сетки на Page_Load, где я проверяю, что это не IsPostBack.Таким образом, при первоначальной загрузке данные привязываются к представлению таблицы, но не связываются снова при пост-посте назад.Остальная часть кода похожа и довольно проста.

Надеюсь, это поможет

Спасибо за предоставление вашего метода Page_Load.Проверьте следующий код:

protected void Page_Load(object sender, EventArgs e)
{
    if(!IsPostBack) {
        var eyeball = Calldatabase.Eyeball();

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