0

我在 Select 语句中加入两个表 - Contact 和 RetailTrainingUserLevelMap。

(两者的共同列是 RetailTrainingUserLevelID int)

选择 Contact.IntranetUserName、Contact.CompanyName、RetailTrainingUserLevelMap.RetailTrainingUserLevel

FROM 联系方式

内部加入 RetailTrainingUserLevelMap ON Contact.RetailTrainingUserLevelID = RetailTrainingUserLevelMap.RetailTrainingUserLevelID

AND Contact.RetailTrainingUserLevelID = RetailTrainingUserLevelMap.RetailTrainingUserLevelID

WHERE (Contact.IntranetUserName = @IntranetUserName)


如果我通过 Visual Studio Query Builder(测试查询窗口)运行此语句,并为“IntranetUserName”输入一个值,我会得到:

内网用户名:
John Joe

公司名称:
Acme Inc.

零售培训用户级别:
经理

这是我想要的输出,到目前为止一切顺利。

如果我在我的 .cs 代码隐藏中使用相同的选择语句,使用 SqlDataReader 将标签绑定到其中一些列,如下所示:

SqlCommand comm;
        SqlConnection conn;
        string intranetConnectionString = ConfigurationManager.ConnectionStrings["DataConnect"].ConnectionString;
        conn = new SqlConnection(intranetConnectionString);
        comm = new SqlCommand("SELECT Contact.IntranetUserName, Contact.CompanyName, RetailTrainingUserLevelMap.RetailTrainingUserLevel FROM Contact INNER JOIN RetailTrainingUserLevelMap ON Contact.RetailTrainingUserLevelID = RetailTrainingUserLevelMap.RetailTrainingUserLevelID AND Contact.RetailTrainingUserLevelID = RetailTrainingUserLevelMap.RetailTrainingUserLevelID WHERE (Contact.IntranetUserName = @IntranetUserName)", conn);

        comm.Parameters.Add("@IntranetUserName", System.Data.SqlDbType.VarChar, 50);
        comm.Parameters["@IntranetUserName"].Value = memberLoginName;

        conn.Open();
        SqlDataReader reader = comm.ExecuteReader();
        while (reader.Read())
        {
            memberCompanyNameLabel.Text += reader["CompanyName"];
           userLevelLabel.Text += reader["RetailTrainingUserLevel"];
        }

        reader.Close();
        conn.Close();

我收到错误“输入字符串的格式不正确。” 这里:
userLevelLabel.Text += reader["RetailTrainingUserLevel"];

此处需要更改哪些C#语法,以便我可以将该值正确绑定到我的 userLevelLabel?

注意:RetailTrainingUserLevelID int
RetailTrainingUserLevel varchar (50)

感谢您的时间和知识。

4

1 回答 1

0

你确定reader["RetailTrainingUserLevel"]不是 DBNull 吗?

在尝试将其添加到另一个字符串之前,可能需要对其执行 .ToString() 。

我会做

userLevelLabel.Text += reader["RetailTrainingUserLevel"].ToString();
于 2009-08-20T16:11:41.220 回答