0

エラーが発生します:

DataBinding: 'System.Data.DataRowView' には、'system_name' という名前のプロパティが含まれていません。

SYSTEMSテーブルからデータを取得するドロップダウン リストがあります。コード:

string queryStringForSystem = "SELECT system_name FROM ptdd.systems where system_id=(select system_id from ptdd.parameters where parameter_id='" + txtParameterId.Text + "')";
string odbccon = "Driver={IBM DB2 ODBC DRIVER};database=dd_unify;hostname=x.x.x.x;protocol=TCPIP;port=50000;uid=xxxx;pwd=xxxx";            
using (System.Data.Odbc.OdbcConnection odbcConnection = new System.Data.Odbc.OdbcConnection(odbccon))
                {
                    System.Data.Odbc.OdbcDataAdapter adapter = new System.Data.Odbc.OdbcDataAdapter(queryStringForSrdRefId, odbccon);
                    System.Data.DataSet dataSet = new System.Data.DataSet();
                    try
                    {
                        odbcConnection.Open();
                        adapter.Fill(dataSet);
                        ddrSystem.DataSource = dataSet.Tables[0];
                        ddrSystem.DataTextField = "system_name";
                        ddrSystem.DataValueField = "system_id";
                        ddrSystem.DataBind();

                    }

                catch (Exception e1)
                {
                    Console.WriteLine(e1.Message);
                }

また、datatextfield と datavalue フィールドについても言及しました。

<asp:DropDownList ID="ddrSystem" runat="server" DataTextField="system_name" DataValueField="system_id">
                </asp:DropDownList>

ただし、それは小さな問題です。それを解決することはできません。

4

1 に答える 1

0

からクエリを変更してみてください

SELECT system_name FROM...

SELECT system_id, system_name FROM...

理由: コードは system_id を探していますが、そのフィールドがクエリにありません。

ddrSystem.DataTextField = "システム名";

ddrSystem.DataValueField = "system_id " ;

于 2015-01-20T18:15:18.890 に答える