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

MS SQL Необработанное исключение типа "System.Data.SqlClient.SqlException" в System.Data.dll

29.01.2021, 10:46. Показов 2936. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Что не так?
Необработанное исключение типа "System.Data.SqlClient.SqlException" в System.Data.dllДополнительные сведения: Нарушено "PK__Employee__20DC23EB27978DD9" ограничения PRIMARY KEY. Не удается вставить повторяющийся ключ в объект "dbo.Employee". Повторяющееся значение ключа: (0).

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
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Windows.Forms.VisualStyles;
 
namespace WindowsFormsApplication2
{
    public partial class Employee : Form
    {
        private SqlConnection connection = null;
        private SqlDataAdapter da = null;
        private DataSet set = null;
        SqlCommandBuilder command = null;
        private DataTable ds = null;
        private int count = 0;
        public Employee()
        {
            InitializeComponent();
            listView1.MouseDoubleClick += ListView1_MouseDoubleClick;
            button1_Add.Click += Button1_Add_Click;
            Show_Baze();
        }
        private void Button1_Add_Click(object sender, EventArgs e)
        {
            Employee_Add A = new Employee_Add(this, ds, count);
            if (A.ShowDialog() == DialogResult.OK)
            {
                Show_Baze();
            }
        }
        private void Show_Baze()
        {
            count = 0;
            listView1.Items.Clear();
            connection = new SqlConnection();
            connection.ConnectionString = ConfigurationManager.ConnectionStrings["MyConnString"].ConnectionString;
            string sqlzaproc = "SELECT * FROM Employee";
            set = new DataSet();
            da = new SqlDataAdapter(sqlzaproc, connection);
            command = new SqlCommandBuilder(da);
            da.Fill(set);
            ds = set.Tables[0];
            string[] row = new string[ds.Columns.Count];
            ListViewItem itm;
            for (int i = 0; i < ds.Rows.Count; i++)
            {
                count++;
                for (int j = 0; j < ds.Columns.Count; j++)
                {
                    row[j] = ds.Rows[i][j].ToString();
                }
                itm = new ListViewItem(row);
                listView1.Items.Add(itm);
 
            }
        }
        public void Updete_teble(DataTable table)
        {
            set = table.DataSet;
            da.Update(set);
        }
        private void ListView1_MouseDoubleClick(object sender, MouseEventArgs e)
        {
            if (e.Button == MouseButtons.Left)
            {
                Employee_Edit A = new Employee_Edit(this, ds, listView1.FocusedItem.Index);
                if (A.ShowDialog() == DialogResult.OK)
                {
                    Show_Baze();
                }
            }
        }
        
    }
}


Может SQL таблицы не так создал
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
CREATE TABLE Employee(
code_clients INT PRIMARY KEY NOT NULL, — Код сотрудника
lastname VARCHAR(40) NOT NULL, — фамилия
firstname VARCHAR(40) NOT NULL, — Имя
middlename VARCHAR(40) NOT NULL, — Отчество
dolzhnost VARCHAR(40) NOT NULL, — Должность
podrazdelenie INT NOT NULL, — Подразделение
data_priema_na_rabotu SMOLLDATETIME — дата приема на работу
)
CREATE TABLE Kids(
code_clients INT PRIMARY KEY NOT NULL,— Код сотрудника
firstname_kid VARCHAR(40) NOT NULL, — Имя ребенка
data_rozhdenya SMALLDATETIME NOT NULL,— Дата рождения
code_kid VARCHAR(40) NOT NULL, — Код ребенка
)
CREATE TABLE Gifts(
code_kid INT PRIMARY KEY NOT NULL, — Код ребенка    
Stoimost_podarka INT NOT NULL, — Стоимость подарка    
data_vydachi_podarka SMALLDATETIME NOT NULL, — Дата выдачи  
code_vydachi VARCHAR(40) NOT NULL,— Код выдачи
)
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.01.2021, 10:46
Ответы с готовыми решениями:

Необработанное исключение типа "System.Data.SqlClient.SqlException" в System.Data.dll
Код формы: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; ...

Необработанное исключение типа "System.Data.SqlClient.SqlException" в System.Data.dll
Всем привет, не очень селен в этом!!! как мне избавится от этой ошибки? Создал базу в SQL, затем добавил в VS2015, Необработанное...

Необработанное исключение типа "System.Data.SqlClient.SqlException" в System.Data.dll
Всем привет! Я новичок в программировании. Собственно говоря учусь основам программирования и.т.д. Проблема в том, что я хочу создать...

2
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
29.01.2021, 12:18
deaddeath, первичный ключ нужно делать identity, тогда, при создании нового объекта он будет создан автоматически.
0
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
29.01.2021, 18:29
Лучший ответ Сообщение было отмечено deaddeath как решение

Решение

Цитата Сообщение от deaddeath Посмотреть сообщение
code_clients INT PRIMARY KEY NOT NULL, — Код сотрудника
SQL
1
code_clients INT IDENTITY(1,1) PRIMARY KEY,

Принято называть первичные ключи-уник.идентификаторы с приставкой ID (Id, id)
Client_Id в Вашем случае. Тогда логика связок в запросах и в коде c# будет легко читаться

Добавлено через 26 минут
Еще принципиальная ошибка.
Каждая таблица должна иметь свой собственный ID

Для Вашей БД должно быть что-то вроде такого:

SQL
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
CREATE TABLE Departament(
  Depart_ID INT IDENTITY(1,1) PRIMARY KEY,  
  Depart_Name VARCHAR(MAX) NOT NULL,
  Depart_ShortName VARCHAR(MAX) NOT NULL
)
CREATE TABLE POSITION(
  Pos_ID INT IDENTITY(1,1) PRIMARY KEY,  
  Pos_Name VARCHAR(MAX) NOT NULL,
  Pos_ShortName VARCHAR(MAX) NOT NULL
)
CREATE TABLE Employee(
  Empl_ID INT IDENTITY(1,1) PRIMARY KEY,  
  Empl_lastname VARCHAR(40) NOT NULL, — фамилия
  Empl_firstname VARCHAR(40) NOT NULL, — Имя
  Empl_middlename VARCHAR(40) NOT NULL, — Отчество
  Empl_Depart INT REFERENCES Departament(Depart_ID), -- ссылка на подразделение
  Empl_Position INT REFERENCES Postion(Pos_ID), -- ссылка на должность
  Empl_Recruitment_date DATETIME — дата приема на работу
)
CREATE TABLE Child(
  Child_ID INT IDENTITY(1,1) PRIMARY KEY,  
  Child_Client INT REFERENCES Departament(Empl_ID), -- ссылка на сотрудника
  Child_Name VARCHAR(40) NOT NULL, — Имя ребенка
  Child_birthday DATETIME,— Дата рождения
)
CREATE TABLE Gift(
  Gift_ID INT IDENTITY(1,1) PRIMARY KEY,  
  Gift_child INT REFERENCES Child(Child_ID) NOT NULL, -- ссылка на ребенка
  Gift_Cost DECIMAL(8,2) NOT NULL, — Стоимость подарка    
  Gift_Date DATETIME NOT NULL, — Дата выдачи  
  Gift_Comments VARCHAR(MAX) — Комментарии
)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.01.2021, 18:29
Помогаю со студенческими работами здесь

Необработанное исключение типа "System.Data.SqlClient.SqlException" в System.Data.dll
Доброго времени суток ! Есть программа, работала нормально. Но как только в соединениях я поменял имя сервера SQL , возникла ошибка при...

Авторизация в приложении и исключение типа "System.Data.SQLClient.SQLException" в System.Data.dll
Доброго времени суток, пробую сделать авторизацию в приложении по примеру. В итоге получил что данные из текстбоксов, наверное,...

Исключение типа "System.Data.SqlClient.SqlException" возникло в System.Private.CoreLib.dll, но не было обработано в коде
Здравствуйте , делал программу для внесения данных в SQL , не могу найти ошибку в данном коде. При вводе данных выдается исключение:...

Необработанное исключение типа "System.Data.SqlClient.SqlException"
Здравствуйте, кто сталкивался с такой ошибкой? &quot;Необработанное исключение типа &quot;System.Data.SqlClient.SqlException&quot; в...

Необработанное исключение типа "System.Data.OleDb.OleDbException" в System.Data.dll
Добрый день, нашел код для вывода двух связанных таблиц данных в один элемент DataGridView. Переделал под себя и выдает такую ошибку: ...


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

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