Click here to Skip to main content
16,022,538 members
Please Sign up or sign in to vote.
0.00/5 (No votes)
See more:
Here i am binding the datatable values with the grid but when the datatable has null values it returns an error

Additional information: Unable to cast object of type 'System.DBNull' to type 'System.Byte[]'.


What I have tried:

<asp:GridView ID="grdDoctorConfirmation" CssClass="table table-striped table-bordered table-hover" runat="server" AutoGenerateColumns="False">
            <Columns>
                <asp:TemplateField HeaderText="Select">
                    <HeaderTemplate>
                        <asp:CheckBox ID="chkAll" runat="server" AutoPostBack="True" />
                    </HeaderTemplate>
                    <ItemTemplate>
                        <asp:CheckBox ID="chkUpdate" runat="server" AutoPostBack="True"  />
                    </ItemTemplate>
                </asp:TemplateField>
                <asp:TemplateField HeaderText="SNo" >
                    <ItemTemplate>
                <%# Container.DataItemIndex + 1 %>
                    </ItemTemplate>
                </asp:TemplateField>
                <asp:BoundField DataField="AppointmentID" HeaderText="ID" HeaderStyle-CssClass="hiddencolumn"  ItemStyle-CssClass="hiddencolumn">
                <HeaderStyle CssClass="hiddencolumn" />
                <ItemStyle CssClass="hiddencolumn" />
                </asp:BoundField>
                <asp:BoundField DataField="PatientID" HeaderText="Patient" />
                <%--<asp:BoundField DataField="DoctorID" HeaderText="Doctor" />--%>
                <asp:BoundField DataField="DoctorName" HeaderText="Doctor" />
                <%--<asp:BoundField DataField="Treatment" HeaderText="Treatment" />--%>
                <asp:BoundField DataField="TreatmentName" HeaderText="Treatment" />
                <asp:BoundField DataField="ADate" HeaderText="Date" DataFormatString="{0:dd/MM/yyyy}"/>
                <asp:BoundField DataField="TreatmentDate" HeaderText="Date" DataFormatString="{0:dd/MM/yyyy}"/>
                <asp:BoundField DataField="ASlotID" HeaderText="Slot" />
                <asp:BoundField DataField="Remarks" HeaderText="Remarks" />
                <asp:TemplateField HeaderText="Photo">
                    <ItemTemplate>
                                    <asp:Image ID="imgPhoto" runat="server" ImageUrl='<%# "data:Image/png;base64,"+Convert.ToBase64String((byte[])Eval("Photo")) %>' Height="50px" Width="50px" />
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
        </asp:GridView>



public void FillRequestAppointment()
        {
            //DateTime today = DateTime.Today;
            //string todaydate = today.ToString("MM/dd/yyyy");
            DataTable dt = dabll.GetDoctorsConfirmation(uCls.UserName);
            obj.FillGrid(grdDoctorConfirmation, dt);
        }
Posted
Updated 31-Dec-17 7:14am

1 solution

try

DataTable dt = dabll.GetDoctorsConfirmation(uCls.UserName);
          dt.AsEnumerable().ToList().ForEach(row =>   row["Photo"] = row["Photo"] == DBNull.Value ? null : row["Photo"] ); // handles dbnull value
          obj.FillGrid(grdDoctorConfirmation, dt);
 
Share this answer
 

This content, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)



CodeProject, 20 Bay Street, 11th Floor Toronto, Ontario, Canada M5J 2N8 +1 (416) 849-8900