Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/48: Рейтинг темы: голосов - 48, средняя оценка - 4.54
0 / 0 / 0
Регистрация: 18.04.2014
Сообщений: 21

Как записать в БД ID выбранного через combobox поля таблицы?

18.04.2014, 11:42. Показов 9918. Ответов 19
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Проблема состоит вот в чем:
есть combobox, привязанный к таблице Client (ClientID, LastName, FirstName, ParentName,Phone):
DisplayMember=LastName
ValueMember=ClientID (не знаю, правильно ли?)
Нужно, чтобы в таблицу Orders базы записывалось поле ClientID выбранного в combobox поля LastName
И еще: а можно ли "склеить" ФИО для отображения в combobox?
c# (VS 2012), SQL
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.04.2014, 11:42
Ответы с готовыми решениями:

Как отобразить через Combobox в datagridview значение 1-й связанной таблицы через 2-ю и записать знач 2-й в 3
Здравствуйте. Уперся в необычную для меня проблему:как отобразить через Combobox в datagridview значение 1-й связанной таблицы через 2-ю и...

Как в поле ID одной таблицы записать значение поля ID другой таблицы
В БД две таблицы: 1)USERS с полями ID_User, Name, Password. В нее записываются пользователи после регистр-ии. 2)SALES с полями...

Как из listbox, combobox и поля записать данные в таблицу
Как из listbox, combobox и поля записать данные в таблицу

19
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
18.04.2014, 12:07
Combobox отдельный или в колонке DataGridView? Форму покажи.
0
 Аватар для nio
6050 / 3460 / 336
Регистрация: 14.06.2009
Сообщений: 8,136
Записей в блоге: 2
18.04.2014, 12:12
Цитата Сообщение от Rua Посмотреть сообщение
Нужно, чтобы в таблицу Orders базы записывалось поле ClientID выбранного в combobox поля LastName
после выбора LastName свойство combobox.SelectedValue возвращает значение твоего ClientID

Цитата Сообщение от Rua Посмотреть сообщение
можно ли "склеить" ФИО для отображения в combobox
в самом боксе нет, это нужно делать запросом
0
0 / 0 / 0
Регистрация: 18.04.2014
Сообщений: 21
18.04.2014, 14:45  [ТС]
Нет, именно combobox
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
18.04.2014, 15:05
Форму покажи. Что там кроме этого combobox? Orders как-то отображается, как они увязаны?
0
0 / 0 / 1
Регистрация: 27.12.2012
Сообщений: 16
19.04.2014, 18:18
если я тебя правильно понял, то надо так
C#
1
2
3
comboBox.DataSource = Connect.GetOrders(); // запрос на получения твоей таблицы
comboBox.DisplayMember = "LastName";
comboBox.ValueMember = "ClientID";
Склеить ФИО, делал в запросе SQL
MySQL
1
CONCAT_WS(  ' ',  `LastName` , MID(  `FirstName` , 1, 1 ) , MID(  `ParentName` , 1, 1 ) ) AS FIO
и выведет тебе "Иванов И И"
0
0 / 0 / 0
Регистрация: 18.04.2014
Сообщений: 21
21.04.2014, 15:48  [ТС]
код вот такой:
C#
1
2
3
4
5
6
7
8
9
private void button1_Click(object sender, EventArgs e)
        {
            SqlConnection conn = new SqlConnection();
            conn.ConnectionString = "Data Source=(local);Initial Catalog=testclient;Integrated Security=True";
            conn.Open();
            SqlCommand sc = new SqlCommand("INSERT INTO Place(ClientID,OrderID,Place) VALUES( "+comboBox1.ValueMember+" , "+comboBox2.ValueMember +" ," + textBox1.Text + ")", conn);
            sc.ExecuteNonQuery();
            MessageBox.Show("Данные добавлены");
        }
Не работает. В этой таблице есть поле PlaceID, оно создано в базе как Identity, и я, честно говоря, не знаю, как его обозначить в запросе.

Вот скриншот формы
Миниатюры
Как записать в БД  ID выбранного через combobox поля таблицы?  
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
21.04.2014, 16:06
Без ключевого поля запись не добавится.

Добавлено через 7 минут
Попробуй так:
"INSERT INTO Place (PlaceID, ClientID, OrderID, Place) VALUES((SELECT 1 + MAX(PlaceID) FROM Place), @ClientID, @OrderID, @Place)"

Параметры (со знаком @) заполни через sc.Parameters
1
0 / 0 / 0
Регистрация: 18.04.2014
Сообщений: 21
21.04.2014, 16:16  [ТС]
Параметры (со знаком @) заполни через sc.Parameters
А можно поподробнее? Код?
Я, честно говоря, только в начале пути...
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
21.04.2014, 16:44
Вот пример того как параметры заполняют (в конце) http://msdn.microsoft.com/ru-r... 10%29.aspx
0
0 / 0 / 0
Регистрация: 18.04.2014
Сообщений: 21
21.04.2014, 18:10  [ТС]
В итоге, код такой:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private void button1_Click(object sender, EventArgs e)
        {
            SqlConnection conn = new SqlConnection();
            conn.ConnectionString = "Data Source=(local);Initial Catalog=testclient;Integrated Security=True";
            conn.Open();
            SqlCommand sc = new SqlCommand("INSERT INTO Place(PlaceID,ClientID,OrderID,Place) VALUES((SELECT 1 + MAX(PlaceID) FROM Place),@ClientID, @OrderID, @Place )", conn);
            sc.Parameters.Add("@ClientID",SqlDbType.Int);
            sc.Parameters["@ClientID"].Value = comboBox1.ValueMember;
            sc.Parameters.Add("@OrderID", SqlDbType.Int);
            sc.Parameters["@OrderID"].Value = comboBox2.ValueMember;
            sc.Parameters.Add("@Place", SqlDbType.NVarChar);                    
            sc.Parameters["@Place"].Value = textBox1.Text;
            sc.ExecuteNonQuery();
            MessageBox.Show("Данные добавлены");
        }
Не выполняется из-за несоответствия типов данных- string и int - а как корректно конвертировать значения combobox в int32?
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
21.04.2014, 19:12
Т. е. у тебя ValueMember строковые? Странно.
C#
1
sc.Parameters["@ClientID"].Value = Convert.ToInt32(comboBox1.ValueMember, 10);
0
0 / 0 / 0
Регистрация: 18.04.2014
Сообщений: 21
22.04.2014, 12:19  [ТС]
Всем большое спасибо за помощь, все получилось.
Но немного по-другому (как выяснилось):
1. В combobox надо указывать не ValueMember, а SelectedMember.
2. Если в базе MSSQL поле идентификатора той таблицы, в которую добавляем данные, стоит IDENTITY, то в запросе его вообще упоминать не нужно - оно добавляется автоматом.
В итоге, код для добавления записи получился такой:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private void button1_Click(object sender, EventArgs e)
        {
            SqlConnection conn = new SqlConnection();
            conn.ConnectionString = "Data Source=(local);Initial Catalog=testclient;Integrated Security=True";
            conn.Open();
            SqlCommand sc = new SqlCommand("INSERT INTO Place(ClientID,OrderID,Place) VALUES(@ClientID, @OrderID, @Place )", conn);
            sc.Parameters.Add("@ClientID",SqlDbType.Int);
            sc.Parameters["@ClientID"].Value = int.Parse(comboBox1.SelectedValue.ToString());
            sc.Parameters.Add("@OrderID", SqlDbType.Int);
            sc.Parameters["@OrderID"].Value = int.Parse(comboBox2.SelectedValue.ToString());
            sc.Parameters.Add("@Place", SqlDbType.NVarChar);                    
            sc.Parameters["@Place"].Value = textBox1.Text;
            sc.ExecuteNonQuery();
            MessageBox.Show("Данные добавлены");
        }
0
 Аватар для nio
6050 / 3460 / 336
Регистрация: 14.06.2009
Сообщений: 8,136
Записей в блоге: 2
22.04.2014, 13:54
Цитата Сообщение от Rua Посмотреть сообщение
1. В combobox надо указывать не ValueMember, а SelectedMember.
ну так об этом я ещё в посте 3 сказал
Цитата Сообщение от nio Посмотреть сообщение
после выбора LastName свойство combobox.SelectedValue возвращает значение твоего ClientID
1
0 / 0 / 0
Регистрация: 18.04.2014
Сообщений: 21
22.04.2014, 15:00  [ТС]
Да, действительно, надо сходить к окулисту, сорри...
И остался один неразрешенный вопрос: а как отобразить в комбобоксе (DisplayMember=LastName) ФИО полностью?
Куда "цеплять" запрос TSQL?
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
22.04.2014, 16:40
SELECT, которым данные выбираешь, подправь как рекомендовал NikKo- и искусственное поле FIO укажи в DisplayMember.
0
0 / 0 / 0
Регистрация: 18.04.2014
Сообщений: 21
22.04.2014, 18:27  [ТС]
Не получается - пишет предупреждение, что
schema returned by the new query differs from the base query
текст запроса такой(на сервере проверен, отрабатывает нормально):

SQL
1
SELECT ClientID, LastName + FirstName + ParentName AS [FIO], Phone FROM dbo.Client
запрос пишу в combobox tasks, Add Query. Если это неправильно, то где его нужно писать?
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
22.04.2014, 18:29
Там вроде так было:
CONCAT_WS( ' ', `LastName` , MID( `FirstName` , 1, 1 ) , MID( `ParentName` , 1, 1 ) ) AS FIO
У тебя MS SQL или MySQL?
0
0 / 0 / 0
Регистрация: 18.04.2014
Сообщений: 21
22.04.2014, 18:39  [ТС]
MSSQL, запрос оттестирован на сервере, работает.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
22.04.2014, 18:53
Может тебе хранимую процедуру там сделать и вызывать?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.04.2014, 18:53
Помогаю со студенческими работами здесь

Как заполнить ComboBox значениями поля таблицы?
Имеется таблица Организация, у нее есть id, наименование и т.д. Как считать все значения поля наименование и добавить их в ComboBox?

Нужно чтоб в ComboBox от одной таблицы отображались значения из соответствующего поля другой таблицы
Нужно чтоб в combobox от одной таблицы отображались значения из соответствующего поля другой таблицы. Настроил отображения этих значений...

Как записать две строки поля одной таблицы в одну строку другой?
Есть такой запрос к БД и результат этого запроса две строки ROH и KOR поля FIL С 6 строки результат запроса заполняется в kbmMemTable1...

Можно ли как нибудь добавить данные из 1 поля 1 таблицы в pickllist другого поля другой таблицы?
Добавить данные в picklist полю ФИО, чтоб получился выпадающий список Бред конечно, ноо... Может есть какие идеи?) ...

Как можно через запрос узнать какие поля у таблицы
Добрый вечер. Интересует меня, как можно через запрос к таблице узнать какие поля у таблицы? Кто нить знает какие нить способы? ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru