1

我在分配值时遇到问题。

 string userlanguages = string.Empty;
        try
        {
            SqlCommand cmd = new SqlCommand("SELECT [s_langName] from [dbo].[tx_UserLanguages] WHERE [s_ID] ='" + Class1.EmployeeId + "'", objcon);
            if (objcon.State == ConnectionState.Closed) objcon.Open();
            SqlDataAdapter adp = new SqlDataAdapter(cmd);
            DataSet myDS = new DataSet();
            adp.Fill(myDS);
            userlanguages = myDS.Tables[0].Rows[0]["[s_langName]"].ToString();
        }
        catch (SqlException exc)
        {
            Response.Write(exc.Message);
        }
        finally
        {
            objcon.Close();
            Class1.langKnwn = userlanguages;
        }
    }

假设,这里的 myDs 包含三个值。那么我将如何将它们分配给单个字符串(在本例中为“用户语言”)。我在另一个页面中使用 Class1.langKnwn 来显示用户选择的语言(在许多情况下可能不止一种语言)。

请帮我。

4

5 回答 5

2

像这样的东西怎么样

List<string> languages = new List<string>();
for (int iRow = 0; iRow < myDS.Tables[0].Rows.Count; iRow++)
    languages.Add(myDS.Tables[0].Rows[iRow]["[s_langName]"].ToString());

userlanguages = String.Join(",", languages);
于 2013-07-25T06:32:57.170 回答
1
        SqlCommand cmd = new SqlCommand("SELECT [s_langName] from [dbo].[tx_UserLanguages] WHERE [s_ID] ='" + Class1.EmployeeId + "'", objcon);
        if (objcon.State == ConnectionState.Closed) objcon.Open();
        SqlDataAdapter adp = new SqlDataAdapter(cmd);
        DataSet myDS = new DataSet();
        adp.Fill(myDS);
        for(int ndx=0;ndx<myDS.Tables[0].Rows.Count;ndx+=1)
         {
             if(ndx==0)
               {
                  userlanguages = myDS.Tables[0].Rows[ndx]["[s_langName]"].ToString();
               }
               else
               {
                  userlanguages = userlanguages+","+ myDS.Tables[0].Rows[ndx]["[s_langName]"].ToString();
               }
         }
于 2013-07-25T06:36:00.323 回答
0

尝试这个

使用using System.Text;命名空间

然后在你的块中编写该代码

 StringBuilder sb = new StringBuilder();
        for (int iRow = 0; iRow < myDS.Tables[0].Rows.Count; iRow++)
        {
            sb.Append(myDS.Tables[0].Rows[iRow]["[s_langName]"].ToString());
            sb.Append(",");
        }

// 获取最后的字符串 string myString = sb.ToString();

myString= myString.Substring(0, myString.Length - 1);

于 2013-07-25T06:39:48.337 回答
0
userlanguages = string.Join(",",  myDS.Tables[0].AsEnumerable()
                                      .Select(row => row.Field<string>("[s_langName]"))
                                      .ToArray());
于 2013-07-25T06:39:55.077 回答
0

如果我正确理解您的问题,SqlDataReader那么在您的情况下使用可能是更好的选择。

using (SqlConnection objcon= new SqlConnection(connectionString))
{
    SqlCommand cmd = new SqlCommand("SELECT [s_langName] from [dbo].[tx_UserLanguages] WHERE [s_ID] = @id", objcon);
    cmd.Parameters.AddWithValue("@id", Class1.EmployeeId);
    connection.Open();

    SqlDataReader reader = cmd .ExecuteReader();

    string userlanguages = string.Empty;
    while (reader.Read())
    {
        string str = reader.GetString(0);
        userlanguages = String.Join(",", userlanguages);
    }
    reader.Close();
}

而且您应该始终使用参数化查询。这种字符串连接对SQL 注入攻击是开放的。

于 2013-07-25T06:38:05.050 回答