powered by simpleCommunicator - 2.0.54     © 2025 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / Не извлекаются значения в функции и вопрос по комбобокс
4 сообщений из 4, страница 1 из 1
Не извлекаются значения в функции и вопрос по комбобокс
    #38926809
2viper2viper
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Прошу Вас помочь в следующем
Создаю программу, которая будет подключаться к sql-серверу.
На форме: грид, два комбобокса
Проблем две:
1). Не подгружаются значения в Комбобокс2. При этом запрос выполняется в SSMS, а, комбобокс 1 при аналогичном подключении но к другой таблице - работает нормально. Может нужно добавить мультипоточность? Но как, не знаю..
2). Функция FillComboCOK() возвращает два поля - id и наименование. Наименование в комбобокс1 добавляется без проблем, но, кроме этого, также нужно по выбранному в комбобоксе1 наименованию использовать его id (для добавления в параметр запроса для Грида - sqlcomm.Parameters.Add("@idCP", System.Data.SqlDbType.Int).Value = 1; Как это сделать, не знаю..)
Буду очень признателен за помощь.

Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data.SqlClient;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data;
 
namespace Export_to_Excel
{
    public partial class Form1 : Form
    {
        DateTime date1;
        public Form1()
        {
            InitializeComponent();
            FillComboCOK();
            FillComboMESYAC();
        }
        void FillComboCOK()  //Функция заполнения комбобокс ЦОКи
        {
            string connstring = @"Data Source";
            string query1 = "select [Код],[ЦОК] from [Access_BD]...[ЦОК];";
            SqlConnection sqlconn = new SqlConnection(connstring);
            SqlCommand sqlcomm1 = new SqlCommand(query1, sqlconn);
            SqlDataReader sqldatareader1;
            try
            {
                sqlconn.Open();
                sqldatareader1 = sqlcomm1.ExecuteReader();
                while (sqldatareader1.Read())
                {
                    string columnname1 = sqldatareader1.GetString(1); 
                    comboBox1.Items.Add(columnname1);
                    comboBox3.Items.Add(columnname1);
                    //string cb1 = comboBox1.Text;
                    //string cb3 = comboBox3.Text;
                }                
            }
            catch (Exception ex) { }
        } 
 
        void FillComboMESYAC()  //Функция заполнения комбобокс Месяца
        {
            string connstring = @"Data Source";
            string query2 = "select month([Дата]) from [Access_BD]...[Платежи_] group by month([Дата]) order by month([Дата]);";
            SqlConnection sqlconn = new SqlConnection(connstring);
            SqlCommand sqlcomm2 = new SqlCommand(query2, sqlconn);
            SqlDataReader sqldatareader2;
            try
            {
                sqlconn.Open();
                sqldatareader2 = sqlcomm2.ExecuteReader();
                while (sqldatareader2.Read())
                {
                    string columnname2 = sqldatareader2.GetString(1);
                    comboBox2.Items.Add(columnname2);
                    
                }                
            }
            catch (Exception ex) { }
        }
 
        private void monthCalendar1_DateChanged(object sender, DateRangeEventArgs e)
        {
            date1 = Convert.ToDateTime(monthCalendar1.SelectionStart.ToString());
           // string queryday = ";";
        }
 
        private void comboBox2_SelectedIndexChanged(object sender, EventArgs e)
        {
            string constring = @"Data Source";
            SqlConnection sqlconn = new SqlConnection(constring);
            SqlCommand sqlcomm = new SqlCommand("Платежи", sqlconn);
            sqlcomm.CommandType = System.Data.CommandType.StoredProcedure;
            sqlcomm.Parameters.Add("@idCP", System.Data.SqlDbType.Int).Value = 1; //Подвязать ID c comboBox1
            string cb2 = comboBox2.Text;
            sqlcomm.Parameters.Add("@month", System.Data.SqlDbType.Int).Value = Convert.ToInt32(cb2);
            try
            {
                SqlDataAdapter sqladap = new SqlDataAdapter(sqlcomm);
                DataTable dtable = new DataTable();
                sqladap.Fill(dtable);
                BindingSource bso = new BindingSource();
                bso.DataSource = dtable;
                dataGridView1.DataSource = bso;
                sqladap.Update(dtable);
            }
            catch (Exception ex) { }
        }
    }
}



По второму вопросу есть варианты
1)
Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
 try
            {
                sqlconn.Open();
                sqldatareader1 = sqlcomm1.ExecuteReader();
                while (sqldatareader1.Read())
                {
                    string columnname2_0 = sqldatareader1.GetString(1);
                    string columnname2_1 = sqldatareader1.GetString(0);
                    comboBox1.ValueMember = columnname2_1;
                    comboBox1.DisplayMember = columnname2_0;
                }         



2)
Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
try
            {
                sqlconn.Open();
                sqldatareader1 = sqlcomm1.ExecuteReader();
 
                    DataTable dt = new DataTable();
                    dt.Columns.Add("[Код]", typeof(Int32));
                    dt.Columns.Add("[ЦОК]", typeof(string));
                    comboBox1.ValueMember = "[Код]";
                    comboBox1.DisplayMember = "[ЦОК]";
                    comboBox1.DataSource = dt;
                    sqlconn.Close();

...
Рейтинг: 0 / 0
Не извлекаются значения в функции и вопрос по комбобокс
    #38926810
2viper2viper
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Но оба не возвращают никаких значений в комбобокс1. Что здесь не правильно?
...
Рейтинг: 0 / 0
Не извлекаются значения в функции и вопрос по комбобокс
    #38926930
2viper2viper
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Задаче решена так:
Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
string connstring = @"Data Source=";
            string query1 = "select [Код],[ЦОК] from [Access_BD]...[ЦОК];";
            SqlConnection sqlconn = new SqlConnection(connstring);
            SqlCommand sqlcomm1 = new SqlCommand(query1, sqlconn);
            try
            {
            sqlconn.Open();
            SqlDataAdapter sqladap1 = new SqlDataAdapter(sqlcomm1);
            DataTable dt1 = new DataTable();
            sqladap1.Fill(dt1);
            comboBox1.ValueMember = "Код";
            comboBox1.DisplayMember = "ЦОК";
            comboBox1.DataSource = dt1;     
            sqladap1.Update(dt1);
            sqlconn.Close();
            }
             catch (Exception ex) { };

...
Рейтинг: 0 / 0
Не извлекаются значения в функции и вопрос по комбобокс
    #38926933
Фотография skyANA
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
2viper2viper, как заполнить ComboBox данными из базы, уже больше 10 лет назад как описано :)

Ввели бы в гугле: how to populate combobox from database in c# .
...
Рейтинг: 0 / 0
4 сообщений из 4, страница 1 из 1
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / Не извлекаются значения в функции и вопрос по комбобокс
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]