繁体   English   中英

参考其他表的ASP.NET Formview下拉列表

[英]ASP.NET Formview dropdown with reference to other table

我有一个包含2个表“ Ingredients”和“ Ingredient Types”的SQL数据库。 在“成分表”中,我有一个与“成分类型PK”链接的外键。

这很好,当我尝试在FK字段中填写不正确的值时,我收到一条错误消息。

但是...我想将编辑表单上的文本框替换为下拉列表,该列表必须显示成分类型表中的值...。(代码为PK,描述要在下拉列表中显示的值)

在我的ASP.NET项目中,我制作了2个SQL数据源(SqlDataSource1-> Ingredients表和SqlDataSource2-> Ingredient Types表)

我创建了一个Formview并将其链接到SqlDataSource1(“成分表”),将文本框替换为下拉列表,并将其链接到SqlDataSource2:

<asp:DropDownList runat="server" ID="unitDropDown" DataSourceID="SqlDataSource2" DataValueField="Code" DataTextField="Description" SelectedValue='<%# Bind("Code") %>' />

当我启动页面时,收到错误消息:'System.Data.DataRowView'不包含名称为Code的属性。

但据我所知,我确实有一个列名Code

我添加了一个截图画面从我的SSMS与2个表.. 数据库

我做错了什么? 还是有更好的方法来实现这一目标?

收到此错误的原因是因为您要绑定到的表SqlDataSource1(BM_Ingridients)中没有名为“代码”的列。

您应该尝试更改为:

SelectedValue='<%# Bind("IngridientType") %>' 

这是ForeignKey refrencing在SqlDatasource2(BM_IngridientsType)的相应值。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM