• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

auto inkrementacja z poziomu kodu w .net

VPS Starter Arubacloud
+1 głos
132 wizyt
pytanie zadane 8 maja 2021 w C# przez kubaa322 Użytkownik (710 p.)

Witam, mam bazę danych gdzie klasycznie znajduje się kolumna ID, która jest ustawiona jako klucz podstawowy z auto inkrementacją. Mam kod, który dodaje użytkownika do bazy i jeśli jest to pierwszy użytkownik to wszystko działa, jednak gdy chcę dodać drugiego to wyskakuje mi błąd: 

Violation of PRIMARY KEY constraint 'PK_Users'. Cannot insert duplicate key in object 'dbo.Users'. The duplicate key value is (0).

kod:

            Console.WriteLine("First Name: ");
            string firstName = Console.ReadLine();

            Console.WriteLine("Last Name: ");
            string lastName = Console.ReadLine();

            Console.WriteLine("Age: ");
            int age = Int32.Parse(Console.ReadLine());

            Console.WriteLine("Number: ");
            int number = Int32.Parse(Console.ReadLine());

            var user = new User(firstName, lastName, age, number);

            string query = $"INSERT INTO Users(ID, [First Name], [Last Name], Age, Number) VALUES(''," +
                           $"'{user.FirstName}', '{user.LastName}', '{user.Age}', '{user.Number}')";
            SqlCommand command = new SqlCommand(query, Connection.Connect());
            command.ExecuteNonQuery();

domyślam się że to chodzi właśnie o to ID w kodzie

2 odpowiedzi

+1 głos
odpowiedź 8 maja 2021 przez SzkolnyAdmin Szeryf (86,280 p.)

Pewnie wysyłasz nadal to samo ID. Pomiń je w zapytaniu:

string query = $"INSERT INTO Users([First Name], [Last Name], Age, Number) VALUES(" +
               $"'{user.FirstName}', '{user.LastName}', '{user.Age}', '{user.Number}')";

 

0 głosów
odpowiedź 8 maja 2021 przez VBService Ekspert (251,210 p.)

Większość baz danych:

Using AUTO_INCREMENT

 

No value was specified for the AUTO_INCREMENT column, so MySQL assigned sequence numbers automatically.

 

INSERT INTO animals (name) VALUES ('penguin');

 

You can also explicitly assign 0 to the column to generate sequence numbers, unless the NO_AUTO_VALUE_ON_ZERO SQL mode is enabled. For example:

 

INSERT INTO animals (id,name) VALUES (0,'groundhog');

 

If the column is declared NOT NULL, it is also possible to assign NULL to the column to generate sequence numbers. For example:

 

INSERT INTO animals (id,name) VALUES (NULL,'squirrel');

 

Podobne pytania

0 głosów
2 odpowiedzi 379 wizyt
pytanie zadane 29 października 2018 w C# przez Sc4red Użytkownik (590 p.)
+1 głos
2 odpowiedzi 864 wizyt
pytanie zadane 9 kwietnia 2021 w C# przez kubaa322 Użytkownik (710 p.)
0 głosów
0 odpowiedzi 410 wizyt
pytanie zadane 17 lutego 2021 w C# przez disaster Bywalec (2,120 p.)

92,453 zapytań

141,262 odpowiedzi

319,088 komentarzy

61,854 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...