有一个表csDeviceSpec,有如下字段:
SpecOID SpecOIDParent SpecAID UOMOID
另一个表csUOM,有如下字段:
UOMOID UOMAID
csUOM与csDeviceSpec是一对多关系。
使用Dynamic Data Linq to SQL模型时。
使用ASPXTreeList元件呈现,用ASPxComboBox来编辑:
<dx:TreeListDataColumn Caption="单位ID" FieldName="csUOM.UOMAID" Width="1px" CellStyle-Wrap="False"> <EditFormSettings Visible="False" /> </dx:TreeListDataColumn> <dx:TreeListDataColumn Caption="单位名称" FieldName="csUOM.Name" Width="1px" CellStyle-Wrap="False"> <EditCellTemplate> <dx:ASPxComboBox runat="server" ID="ComboBox_UOM" ValueType="System.Int32" DataSourceID="DataSource_UOM" TextField="UOMAID" ValueField="UOMOID" Value='<%#Bind("UOMOID") %>'> <Columns> <dx:ListBoxColumn FieldName="UOMAID" Caption="单位ID"></dx:ListBoxColumn> <dx:ListBoxColumn FieldName="Name" Caption="单位名称"></dx:ListBoxColumn> </Columns> </dx:ASPxComboBox> </EditCellTemplate> </dx:TreeListDataColumn>
但是,在新增时总是出现这样的错误:未将对象引用设置到对象的实例。
只有在dbml模型中,把csUOM与csDevice的关联删除后,并用如下方式来编辑,才一切恢复正常。
<dx:TreeListComboBoxColumn Caption="单位ID" FieldName="UOMOID" Width="1px" CellStyle-Wrap="False"> <PropertiesComboBox DataSourceID="DataSource_UOM" TextField="UOMAID" ValueField="UOMOID"> <Columns> <dx:ListBoxColumn FieldName="UOMAID" Caption="单位ID"></dx:ListBoxColumn> </Columns> </PropertiesComboBox> <EditCellTemplate> <dx:ASPxComboBox runat="server" ID="ComboBox_UOM" ValueType="System.Int32" DataSourceID="DataSource_UOM" TextField="UOMAID" ValueField="UOMOID" Value='<%#Bind("UOMOID") %>'> <Columns> <dx:ListBoxColumn FieldName="UOMAID" Caption="单位ID"></dx:ListBoxColumn> <dx:ListBoxColumn FieldName="Name" Caption="单位名称"></dx:ListBoxColumn> </Columns> </dx:ASPxComboBox> </EditCellTemplate> </dx:TreeListComboBoxColumn> <dx:TreeListComboBoxColumn Caption="单位名称" FieldName="UOMOID" Width="1px" CellStyle-Wrap="False"> <EditFormSettings Visible="False" /> <PropertiesComboBox DataSourceID="DataSource_UOM" TextField="Name" ValueField="UOMOID"> <Columns> <dx:ListBoxColumn FieldName="Name" Caption="单位名称"></dx:ListBoxColumn> </Columns> </PropertiesComboBox> </dx:TreeListComboBoxColumn>