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

Внесение значения NULL

12.05.2022, 08:02. Показов 609. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не получается ввести значение NULL в бд. Либо Код_юр_лица, либо Код_физ_лица должен иметь нулевое значение в записи. При вводе выдает ошибку. Все прикреплено
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
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
 
namespace DataBase
{
    public partial class New_Dogovor : Form
    {
 
        DataBase dataBase = new DataBase();
 
        public New_Dogovor()
        {
            InitializeComponent();
            StartPosition = FormStartPosition.CenterScreen;
        }
 
        private void textBox5_TextChanged(object sender, EventArgs e)
        {
 
        }
 
        private void label5_Click(object sender, EventArgs e)
        {
 
        }
 
        private void New_Dogovor_Load(object sender, EventArgs e)
        {
 
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            dataBase.OpenConnection();
 
            string nul = null;
            var id = textBox1.Text;
            var id_room = textBox4.Text;
            var id_doc = textBox5.Text;
            var id_ur = textBox7.Text;
            var id_phys = textBox6.Text;
            var date_zak = dateTimePicker1.Value.Date;
            var date_arenda = dateTimePicker2.Value.Date;
            if (id_phys == "")
            {
                var addQuery = $"insert into Договоры (Код_договора, Дата_заключения, Дата_начала_аренды, Код_помещения, Код_документа_ГКРФ, Код_юр_лица, Код_физ_лица) values ('{id}', '{date_zak}', '{date_arenda}', '{id_room}', '{id_doc}', '{id_ur}', '{nul}')";
                var command = new SqlCommand(addQuery, dataBase.getConnection());
 
                command.ExecuteNonQuery();
 
                MessageBox.Show("Запись успешно создана!", "Успех!", MessageBoxButtons.OK, MessageBoxIcon.Information);
 
                dataBase.CloseConnection();
            }
            if (id_ur == "")
            {
                var addQuery = $"insert into Договоры (Код_договора, Дата_заключения, Дата_начала_аренды, Код_помещения, Код_документа_ГКРФ, Код_юр_лица, Код_физ_лица) values ('{id}', '{date_zak}', '{date_arenda}', '{id_room}', '{id_doc}', '{nul}', '{id_phys}')";
                var command = new SqlCommand(addQuery, dataBase.getConnection());
 
                command.ExecuteNonQuery();
 
                MessageBox.Show("Запись успешно создана!", "Успех!", MessageBoxButtons.OK, MessageBoxIcon.Information);
 
                dataBase.CloseConnection();
            }
 
        }
    }
}
Миниатюры
Внесение значения NULL   Внесение значения NULL   Внесение значения NULL  

0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.05.2022, 08:02
Ответы с готовыми решениями:

Получение значения CheckBox и внесение его значения в БД
Нужно получить значение checkbox и ввести эти данные в ячейку таблицы базы данных как Текст. Мой код if ((Combobox1.Text ==...

EF: null-значения
Есть такое описание свойства: public class SomeUnit { public int? SomeValue { get; set; } } Есть...

Внесение значения из класса Main в класс Telephone
Доброго времени суток! Помогите пожалуйста справиться с двумерным массивом. По условию необходимо создать базу контактов, где будет...

11
 Аватар для Andrey-MSK
3349 / 2235 / 388
Регистрация: 14.08.2018
Сообщений: 7,557
Записей в блоге: 4
12.05.2022, 08:19
Цитата Сообщение от Stalin1897 Посмотреть сообщение
Не получается ввести значение NULL в бд.
Поле в таблице должно иметь свойство NULL, галочка должна стоять напротив поля в редакторе. Тогда оно будет принимать значения NULL.
0
1 / 1 / 0
Регистрация: 21.12.2020
Сообщений: 63
12.05.2022, 08:26  [ТС]
Andrey-MSK, то есть ключевое поле должно допускать значение NULL?
0
 Аватар для Andrey-MSK
3349 / 2235 / 388
Регистрация: 14.08.2018
Сообщений: 7,557
Записей в блоге: 4
12.05.2022, 08:30
Цитата Сообщение от Stalin1897 Посмотреть сообщение
то есть ключевое поле должно допускать значение NULL
А причем тут ключевое поле? Ключевое поле всегда использует автогенерацию ID и никогда не показывается пользователю, а только для связей связей таблиц и других технических нужд.
0
1 / 1 / 0
Регистрация: 21.12.2020
Сообщений: 63
12.05.2022, 08:54  [ТС]
Просто в таблице договоры NULL разрешен, а ошибка связан с другими таблицами в зависимости от того поля, которое оставляю пустым в форме
Миниатюры
Внесение значения NULL  
0
 Аватар для Andrey-MSK
3349 / 2235 / 388
Регистрация: 14.08.2018
Сообщений: 7,557
Записей в блоге: 4
12.05.2022, 09:12
Stalin1897, Вот смотрите. Первая таблица главная, у неё есть свой ID с автоинкрементом, это поле также является ключевым
T-SQL
1
2
3
4
5
6
7
8
9
CREATE TABLE [dbo].[tblEObject](
    [ID_EObject] [int] IDENTITY(1,1) NOT NULL, -- ключевое поле
    [EObjectName] [nvarchar](200) NULL,
 CONSTRAINT [PK_tblEObject] PRIMARY KEY CLUSTERED -- сам ключ в таблице
(
    [ID_EObject] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
Вот вторая таблица, у неё своё ключевое поле и есть поле для связи с главной таблицей, и это поле может принимать NULL
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE TABLE [dbo].[tblGenPlan](
    [ID_GenPlan] [int] IDENTITY(1,1) NOT NULL, -- ключевое поле
    [KKS] [nvarchar](50) NULL,
    [GPName] [nvarchar](255) NULL,
    [ID_EObject] [int] NULL, -- внешнее поле для связи
 CONSTRAINT [PK_tblGenPlan] PRIMARY KEY CLUSTERED -- ключ таблицы
(
    [ID_GenPlan] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
 
-- внешний ключ на главную таблицу
ALTER TABLE [dbo].[tblGenPlan]  WITH CHECK ADD  CONSTRAINT [FK_tblGenPlan_tblEObject] FOREIGN KEY([ID_EObject])
REFERENCES [dbo].[tblEObject] ([ID_EObject]) 
GO
 
-- ограничение внешнего ключа
ALTER TABLE [dbo].[tblGenPlan] CHECK CONSTRAINT [FK_tblGenPlan_tblEObject]
GO
Теперь понятно?
0
1 / 1 / 0
Регистрация: 21.12.2020
Сообщений: 63
12.05.2022, 09:31  [ТС]
Я понял, и у меня разрешено NULL во второй таблице, если перенести мою работу на Ваш пример
0
 Аватар для Andrey-MSK
3349 / 2235 / 388
Регистрация: 14.08.2018
Сообщений: 7,557
Записей в блоге: 4
12.05.2022, 09:36
Stalin1897, Если вы добавляете данные в две таблицы сразу, то будет ошибка.
Нужно делать так
1. Добавить новые данные в главную таблицу.
2. Получить ID новой записи в главной таблице (SCOPE_IDENTITY (Transact-SQL)).
3. Подставить этот ID в запрос на INSERT во вторую таблицу. Тогда целостность ключа не будет нарушена и данные запишутся.
0
1 / 1 / 0
Регистрация: 21.12.2020
Сообщений: 63
12.05.2022, 09:40  [ТС]
Ну так а мне вместо новой записи, то есть нового айдишника, нужно ввести нулл, потому что договор может быть заключен как с физ, так и с юр, но не с обоими одновременно
0
 Аватар для Andrey-MSK
3349 / 2235 / 388
Регистрация: 14.08.2018
Сообщений: 7,557
Записей в блоге: 4
12.05.2022, 10:13
Stalin1897, Куда вы пытаетесь внести данные? Покажите таблицу и связи.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
12.05.2022, 10:17
Stalin1897, Вангую, что вместо кода физ/юр лица вы пытаетесь всунуть название.
0
 Аватар для Andrey-MSK
3349 / 2235 / 388
Регистрация: 14.08.2018
Сообщений: 7,557
Записей в блоге: 4
12.05.2022, 10:30
Если в таблицы которые на картинках, то такое делать нельзя, от слова совсем. У вас ведь там ключевые поля...
NULL может быть внесён только во внешее поле подчинённой таблицы.

Добавлено через 11 минут
Igr_ok, Да тут походу ТС хочет ключевое поле с NULL замутить... Путает главные таблицы и подчинённые...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.05.2022, 10:30
Помогаю со студенческими работами здесь

Внесение значения с опр-ны условиями в поле NULL
Добрый день. Есть такой вопрос. НА скрине указано: столбец shp_code последняя запись NULL.Как можно, при определнных условиях, внести в это...

Не удалось вставить значение NULL в столбец "Sum"; в столбце запрещены значения NULL
Помогите пожалуйста с решением данной ошибки Не удалось вставить значение NULL в столбец "Sum", таблицы...

Внесение значения из JTextField в массив
Добрый вечер. Изучаю Java и вот застрял на вопросе: Внесение данных из JTextField в массив. Приведите пожалуйста пример который...

Присвоение значения полю/внесение поля в бд
Доброго времени суток! Есть БД на которую сделана форма авторизации и есть несколько юзеров с разными правами. Пытаюсь сделать такую...

Внесение в элемент загрузки значения .part
Доброго времени суток) столкнулся с такой проблемкой при загрузке файла через свой загрузчик: Загружается файл и внезапно выключается...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru