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

insert and update razem?

Object Storage Arubacloud
+1 głos
216 wizyt
pytanie zadane 29 marca 2019 w PHP przez eyeys Początkujący (260 p.)

Hej, nie wyskakuje mi błąd, a myślę że mam coś źle w tym zapytaniu sql

insert into pm (id, id2, title, user1, user2, message, timestamp, user1read, user2read)values($id, $rows, '', $usersessionid, '', $message, $time, '', '') and update pm set user=$user_partic read='yes' where id=$id and id2=1

Czy może być w taki sposób wpisany insert and update czy zła składnia?

2 odpowiedzi

+1 głos
odpowiedź 29 marca 2019 przez Chess Szeryf (76,710 p.)
edycja 29 marca 2019 przez Chess

Nieprawidłowa składnia, popatrz tutaj:

https://dev.mysql.com/doc/refman/8.0/en/insert.html

https://dev.mysql.com/doc/refman/8.0/en/insert-on-duplicate.html

Po zobaczeniu przykładów wszystko powinno stać się jasne.

Ogółem poczytaj trochę:

https://4programmers.net/Forum/Bazy_danych/195871-on_duplicate_key

create table txxx2 ( col1 int auto_increment primary key, col2 date not null, col3 varchar(20) default 0, unique key (col2));
insert into txxx2 (col1, col2) values(null, '2012-03-03') on duplicate key update col3 = col3 + 1;
select * from txxx2;
+------+------------+------+
| col1 | col2       | col3 |
+------+------------+------+
|    1 | 2012-03-03 | 0    |
+------+------------+------+
insert into txxx2 (col1, col2) values(null, '2012-03-03') on duplicate key update col3 = col3 + 1;
select * from txxx2;
+------+------------+------+
| col1 | col2       | col3 |
+------+------------+------+
|    1 | 2012-03-03 | 1    |
+------+------------+------+
 insert into txxx2 (col1, col2) values(null, '2012-03-03') on duplicate key update col3 = col3 + 1;
select * from txxx2;
+------+------------+------+
| col1 | col2       | col3 |
+------+------------+------+
|    1 | 2012-03-03 | 2    |
+------+------------+------+
insert into txxx2 (col1, col2) values(null, '2012-03-04') on duplicate key update col3 = col3 + 1;
select * from txxx2;
+------+------------+------+
| col1 | col2       | col3 |
+------+------------+------+
|    1 | 2012-03-03 | 2    |
|    4 | 2012-03-04 | 0    |
+------+------------+------+

Przy pierwszych trzech insert'ach do bazy trafiły tak jakby 3 rekordy mimo iż jest w bazie tylko jeden wiersz, który ma kolumnę col3, która mówi ile poleciało już insertów w trzym przypadku 3 inserty poleciały do bazy z taką samą wartością, którą jest 2012-03-03. Dałem definicję w tworzeniu tabeli default 0, więc domyślnie jest na zero, zatem licząc od zera do dwóch daje nam to 3 (trzy) rekordy w bazie jako jeden wiersz.

Zasada jest taka ... on duplicate key update ... zależnie od warunku wykonuje określoną akcję na zdublowanych wartościach, (ale kolumna, która ma zdublowane wartości musi chyba mieć np. unique utworzony) a w tym przypadku sumuje duplikaty.

0 głosów
odpowiedź 30 marca 2019 przez Comandeer Guru (600,810 p.)

W MySQL (i bodaj PostgreSQL) jest jeszcze coś takiego jak REPLACE – może być w niektórych sytuacjach nieco bardziej eleganckim zastępstwem dla INSERT ON DUPLICATE KEY UPDATE

Podobne pytania

+2 głosów
1 odpowiedź 328 wizyt
+5 głosów
0 odpowiedzi 7,947 wizyt
pytanie zadane 18 sierpnia 2016 w Nasze poradniki przez Mirosław Zelent Nałogowiec (34,750 p.)
0 głosów
1 odpowiedź 224 wizyt
pytanie zadane 25 maja 2020 w PHP przez spicedagger Użytkownik (530 p.)

92,555 zapytań

141,403 odpowiedzi

319,557 komentarzy

61,940 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

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy 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!

...