1

我有一个从具有整数属性hide的表生成的实体。我在部分类HideBoolean中创建了一个自定义属性,以将整数属性转换为布尔值。

    Public Property HideBoolean As Boolean
        Get
            Return If(hide = 1, True, False)
        End Get
        Set(ByVal value As Boolean)
            Me.hide = If(value, 1, 0)
        End Set
    End Property

我正在使用连接到实体的实体数据源来数据绑定到表单视图,布尔属性是数据绑定到复选框。在更新 formview 上的记录时,我收到以下错误消息

在插入、更新或 >delete 操作期间,在实体上找不到名为“HideBoolean”的属性。检查以确保指定为绑定表达式的属性 > 可用于数据源。

我已经在 setter 上进行了一些日志记录,并且更新没有受到影响。

为了测试实体,我尝试更改代码中记录的布尔属性的值并保存记录,这很有效。

        Dim a As New Data.PortalEntities
        Dim r As Data.Reports_Reports = a.Reports_Reports.Where(Function(b) b.reportID = reportID).FirstOrDefault
        r.HideBoolean = Not r.HideBoolean
        a.SaveChanges()

表中的值已成功更改。

编辑:这是我的 aspx 中的代码

<asp:EntityDataSource ID="EntityDataSource1" runat="server" ConnectionString="name=PortalEntities" DefaultContainerName="PortalEntities" 
    EnableFlattening="False" EnableUpdate="True" EntitySetName="Reports_Reports" AutoGenerateWhereClause="true">
    <WhereParameters>
        <asp:Parameter DefaultValue="311" Name="reportID" Type="Int32" />
    </WhereParameters>
</asp:EntityDataSource>
<asp:FormView ID="FormView1" runat="server" DataKeyNames="reportID" DataSourceID="EntityDataSource1" DefaultMode="Edit">
    <EditItemTemplate>
        HideBoolean:
        <asp:CheckBox ID="HideBooleanCheckBox" runat="server" Checked='<%# Bind("HideBoolean") %>' />
        <asp:LinkButton ID="UpdateButton" runat="server" CausesValidation="True" CommandName="Update" Text="Update" />
        <asp:LinkButton ID="UpdateCancelButton" runat="server" CausesValidation="False" CommandName="Cancel" Text="Cancel" />
    </EditItemTemplate>
</asp:FormView>
4

0 回答 0