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

Извлечение первичного ключа

22.05.2014, 15:10. Показов 1528. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Уважаемы форумчане!

Подскажите пожалуйста, как извлечь первичный ключ одной таблицы чтобы его потом сохранить в другой.
Есть две таблицы:
таблица Flight с полями (ID, StartFlight, EndFlight)
и
таблица FlightParametrs с полями (ID, ID_Flight, Altitude, Speed, GrossWeight).

На форме заполняю данные для обоих таблиц. Теперь при сохранении - данные с формы перекочуют в таблицу Flight, так же и в таблицу FlightParametrs. Однако как в таблицу FlightParametrs поле ID_Flight вставить значение первичного ключа из таблицы Flight?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.05.2014, 15:10
Ответы с готовыми решениями:

Получение первичного ключа
Не могу найти решения следующего вопроса. У меня имеется таблица, где id является инкрементом и первичным ключом. В следующей строке: ...

Изменение значения первичного ключа
В таблице БД есть первичный ключ ProductID, который вручную не изменяется, при добавлении данных через Query запрос (INSERT), у меня отсчет...

EF и Ошибка при изменении первичного ключа
Использу EF Code first. Есть сущность с составным ключом. В ключе 3 поля, и ни одно нельзя изменить. вылетает эксепшн : Произошло...

12
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
22.05.2014, 15:29
Цитата Сообщение от ac1-caesar Посмотреть сообщение
как в таблицу FlightParametrs поле ID_Flight вставить значение первичного ключа из таблицы Flight?
Зависит от СУБД
0
124 / 3 / 0
Регистрация: 29.07.2013
Сообщений: 249
22.05.2014, 16:16  [ТС]
СУБД SQL
0
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,247
22.05.2014, 16:23
sql это язык. Microsoft sql sever у вас?
0
124 / 3 / 0
Регистрация: 29.07.2013
Сообщений: 249
22.05.2014, 16:38  [ТС]
Цитата Сообщение от Монфрид Посмотреть сообщение
sql это язык. Microsoft sql sever у вас?
Да Microsoft sql server
0
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,247
22.05.2014, 16:43
вам после добавления записи в одну таблицу нужно запрашивать значение первичного ключа через запрос
SQL
1
SELECT SCOPE_IDENTITY()
0
124 / 3 / 0
Регистрация: 29.07.2013
Сообщений: 249
22.05.2014, 16:49  [ТС]
Цитата Сообщение от Монфрид Посмотреть сообщение
вам после добавления записи в одну таблицу нужно запрашивать значение первичного ключа через запрос
как это выглядит на C#?
0
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,247
22.05.2014, 17:08
так же, как вы сохраняете данные в таблицы с формы
0
124 / 3 / 0
Регистрация: 29.07.2013
Сообщений: 249
22.05.2014, 17:19  [ТС]
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
private void SAVE_button_Click_1(object sender, EventArgs e)
        {
            SqlConnection con = new SqlConnection(@"Data Source=ALEX;Initial Catalog=EPS;Integrated Security=True;Connect Timeout=15;Encrypt=False;TrustServerCertificate=False;");
            con.Open();
            SqlCommand flt = new SqlCommand("Insert into [Flight] (StartFlight, EndFlight) VALUES ('" + StartFlight.Text + "','" + EndFlight.Text + "')", con);
            SqlCommand rpwo = new SqlCommand("Insert into [FlightParametrs] (ID_Flight, Altitude, Speed, GrossWeight) VALUES ('" + Altitude.Text + "','" + Speed.Text + "','" + GrossWeight.Text + "')", con);
            
                flt.ExecuteNonQuery();
                rpwo.ExecuteNonQuery();
                
                MessageBox.Show("Records inserted");
                con.Close();
            }
Вот мой код сохранения. Но как вставить индекс таблицы Flight?
0
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,247
22.05.2014, 17:27
ну вы вместо inserta вставьте select, получите результат, потом этот результат вставьте в insert
0
124 / 3 / 0
Регистрация: 29.07.2013
Сообщений: 249
22.05.2014, 17:30  [ТС]
Цитата Сообщение от Монфрид Посмотреть сообщение
ну вы вместо inserta вставьте select, получите результат, потом этот результат вставьте в insert
а select чего? и как выбрать крайнее значение? не могли бы строчку набросать?
0
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,247
22.05.2014, 17:48
я вам писал ранее запрос, эту строку используйте.
И вместо ExecuteNonQuery(), для выборки используйте ExecuteScalar()
0
124 / 3 / 0
Регистрация: 29.07.2013
Сообщений: 249
22.05.2014, 17:55  [ТС]
Монфрид, спасибо. Буду мудрить.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.05.2014, 17:55
Помогаю со студенческими работами здесь

Добавить строку в БД без первичного ключа
Есть таблица с двумя столбцами: - id - первичный ключ - value - значение int Я пытаюсь добавить данные следующим образом: ...

Входит ли колонка в состав первичного ключа
Доброго времени суток всем! Бьюсь над, казалось бы, простой задачей уже третий день. Глухо. Имеем БД, добавленную в Visual Studio в...

Получение Первичного ключа внесенной записи
Здраствуйте!! Подскажите пожалуйста как вернуть первичный ключ внесенной записи! Я использую OleDataAdapter.InsertCommand с...

Не удаляется запись из таблицы. Нет первичного ключа
Доброго времени суток. Возникла такая проблема: есть 3 таблицы Library { BookName - Primary key } Author { ...

Обновление первичного ключа после выполнения запроса
У меня в классе есть такой метод: public void Delete(int id) { using (SqlCeConnection cn = new...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
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