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

question-closed SQL multi update

Object Storage Arubacloud
0 głosów
124 wizyt
pytanie zadane 12 marca 2017 w SQL, bazy danych przez Alex.Ironside Stary wyjadacz (14,900 p.)
zamknięte 12 marca 2017 przez Alex.Ironside

Witam. Moim pragnieniem jest napisac kwerende ktora zrobi update na tabeli dla kazdej kolumny z ta sama profesja. Zgaduje ze trzeba uzyc subqueries ale jeszcze nie rozumiem ich za dobrze. Jakies pomysly?

CREATE TABLE `my_contacts` (
  `last_name` varchar(30) ,
  `first_name` varchar(20) ,
  `email` varchar(50) ,
  `gender` char(1),
  `birthday` date ,
  `profession` varchar(50),
  `location` varchar(50),
  `status` varchar(20),
  `interests` varchar(100),
  `seeking` varchar(100)
);

INSERT INTO `my_contacts` (`last_name`,`first_name`,`email`,`gender`,`birthday`, `profession`,`location`) VALUES ('Toth','Anne','Anne_Toth@leapinlimos.com','F','1969-11-18', 'Artist','San Fran, CA');
INSERT INTO `my_contacts` (`last_name`,`first_name`,`email`,`gender`,`birthday`, `profession`,`location`) VALUES ('Manson','Anne','am86@objectville.net','F','1977-08-09', 'Baker','Seattle, WA');
INSERT INTO `my_contacts` (`last_name`,`first_name`,`email`,`gender`,`birthday`, `profession`,`location`) VALUES ('Hardy','Anne','anneh@b0tt0msup.com','F','1963-04-18', 'Teacher','San Fran, CA');
INSERT INTO `my_contacts` (`last_name`,`first_name`,`email`,`gender`,`birthday`, `profession`,`location`) VALUES ('Parker','Anne','annep@starbuzzcoffee.com','F','1983-01-10', 'Student','San Fran, CA');
INSERT INTO `my_contacts` (`last_name`,`first_name`,`email`,`gender`,`birthday`, `profession`,`location`) VALUES ('Blunt','Anne','anneblunt@breakneckpizza.com','F','1959-10-09', 'Web Designer','San Fran, CA');
INSERT INTO `my_contacts` (`last_name`,`first_name`,`email`,`gender`,`birthday`, `profession`,`location`) VALUES ('Jacobs','Anne','anne99@objectville.net','F','1968-02-05', 'Computer Programmer','San Jose, CA');

CREATE TABLE profession(
profession_id INT PRIMARY KEY NOT NULL AUTO_INCREMENT,
profession VARCHAR(50)
)AS SELECT profession FROM my_contacts GROUP BY profession ORDER BY profession;

SELECT * FROM profession;

ALTER TABLE my_contacts ADD profession_id INT;
ALTER TABLE my_contacts ADD CONSTRAINT pk_profession_id_professions_fk_profession_id_my_contacts FOREIGN KEY my_contacts(profession_id) REFERENCES profession(profession_id);
UPDATE my_contacts SET my_contacts.profession_id = profession.profession_id WHERE profession(profession) = my_contacts(profession);

Ten ostatni update nie dziala. 

komentarz zamknięcia: Rozwiazanie UPDATE my_contacts SET profession_id = (SELECT profession_id FROM profession WHERE profession.profession=my_contacts.profession);

Podobne pytania

0 głosów
1 odpowiedź 1,360 wizyt
0 głosów
2 odpowiedzi 185 wizyt
pytanie zadane 9 kwietnia 2017 w SQL, bazy danych przez Zahrad Użytkownik (740 p.)
0 głosów
2 odpowiedzi 182 wizyt
pytanie zadane 9 kwietnia 2017 w SQL, bazy danych przez Zahrad Użytkownik (740 p.)

92,539 zapytań

141,382 odpowiedzi

319,481 komentarzy

61,928 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!

...