0

2 つのリストボックスがあり、対応するデータは SQL Server に格納されています。SQL Server から ListBox1 のデータを読み込むことができました。しかし、選択した項目の対応するデータを ListBox 1 から ListBox 2 に入力することはできません。しかし、Listbox 1 の項目をクリックすると、Listbox2 にデータが表示されません。

private void Form2_Load(object sender, EventArgs e)
        {
            SqlConnection cs = new SqlConnection(@"Data Source=.\sqlexpress;Initial Catalog=details;User ID=sa;Password=P@ssw0rd");
            SqlCommand cmd = new SqlCommand();
            cmd.Connection = cs;
            cmd.CommandType = CommandType.Text;
            cmd.CommandText = "SELECT memo FROM new";
        DataSet objDS = new DataSet();
        SqlDataAdapter da = new SqlDataAdapter();
        da.SelectCommand = cmd;

       // cs.Open();
        da.Fill(objDS);

        //cs.Close();

        listMemo.ValueMember = "memo";
        listMemo.DisplayMember = "memo";
        listMemo.DataSource = objDS.Tables[0];

    }


    private void listMemo_SelectedIndexChanged(object sender, EventArgs e)
    {
       // string memo = Convert.ToInt32(listMemo.SelectedValue.ToString());
        if (listMemo.SelectedValue.ToString() != "")
        {
            string memo = Convert.ToString(listMemo.SelectedValue.ToString());
            filltext(memo);
        }


    }


    private void filltext(string memo)
    {
        SqlConnection cs = new SqlConnection(@"Data Source=.\sqlexpress;Initial Catalog=details;User ID=sa;Password=P@ssw0rd");
        SqlCommand cmd = new SqlCommand();
        cmd.Connection = cs;
        cmd.CommandType = CommandType.Text;
        cmd.CommandText = "SELECT text FROM new WHERE memo = '"+ listMemo.SelectedValue.ToString()  +"'" ;
        //cmd.Parameters.AddWithValue("@memo", listMemo);

        DataSet objDS = new DataSet();
        SqlDataAdapter da = new SqlDataAdapter();
        da.SelectCommand = cmd;

       // cs.Open();
        da.Fill(objDS);

     //   cs.Close();

        if (objDS.Tables[0].Rows.Count >0)
        {
            listText.ValueMember = "text";
            listText.DisplayMember = "text";
            listText.DataSource = objDS.Tables[0];

        }

    }
4

1 に答える 1