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

MySQL - wyświetl wszystkie pola, które nie są kluczami

VPS Starter Arubacloud
0 głosów
323 wizyt
pytanie zadane 15 marca 2021 w SQL, bazy danych przez klaudia233 Nowicjusz (180 p.)
Z tabel tabela1, tabela2, tabela3 wyświetl wszystkie pola, które nie są kluczami. Nie wiem jakich poleceń użyć, umiem wyświetlić pola, ale nie umiem wyświetlić tylko tych pól, które nie są kluczami.

3 odpowiedzi

+1 głos
odpowiedź 15 marca 2021 przez Wiciorny Ekspert (269,120 p.)
Pytanie jakie klucze wiążące sa u Ciebie w bazie danych, czy tylko główne, czy jakieś inne kolumny
https://dev.mysql.com/doc/refman/8.0/en/exists-and-not-exists-subqueries.html
warto mieć na uwadze ze klucz to relacja, czyli wybrać te elementy które nie znajdują się w danej tabeli, dla dwóch tabel to coś w stylu ELEMENTÓW które nie należą do obu tabel jednocześnie :)
Czyli FULL outher join ;] z odpowiednim warunkiem
0 głosów
odpowiedź 15 marca 2021 przez areklipno Stary wyjadacz (11,930 p.)
edycja 16 marca 2021 przez areklipno


wg mnie można zrobić to tak:

show columns from tabela1 where `key` = ''

 

komentarz 15 marca 2021 przez Wiciorny Ekspert (269,120 p.)
no nie, bo kluczem może być każda kolumna tabeli. Kluczem nazywamy rekord- który jest powiązany z inną tabelą, nie musi to być główny, może to być zwykły klucz...
Więc musi wybrać wszystkie  rekordy, kolumny które nie sa w relacji z inną tabelą
komentarz 16 marca 2021 przez areklipno Stary wyjadacz (11,930 p.)
w dokumentacji masz to ładnie opisane:

https://dev.mysql.com/doc/refman/8.0/en/show-columns.html

jeśli kolumnie key jest pusto - koluma w tabeli nie jest kluczem
0 głosów
odpowiedź 16 marca 2021 przez PreZmyK Pasjonat (21,470 p.)
edycja 16 marca 2021 przez PreZmyK
SELECT COLUMN_NAME, TABLE_NAME
FROM information_schema.COLUMNS
WHERE TABLE_SCHEMA = 'TWOJA NAZWA' 
AND TABLE_NAME IN ('TABELA1', 'TABELA2', 'TABELA3')
AND COLUMN_NAME NOT IN 
    (SELECT COLUMN_NAME
    FROM information_schema.KEY_COLUMN_USAGE);

 

Podobne pytania

0 głosów
0 odpowiedzi 169 wizyt
pytanie zadane 10 kwietnia 2020 w SQL, bazy danych przez sCoreee Nowicjusz (120 p.)
0 głosów
1 odpowiedź 209 wizyt
pytanie zadane 17 stycznia 2019 w PHP przez chmod96 Obywatel (1,380 p.)
0 głosów
2 odpowiedzi 140 wizyt
pytanie zadane 11 kwietnia 2020 w SQL, bazy danych przez lukasz1390 Użytkownik (500 p.)

92,455 zapytań

141,263 odpowiedzi

319,099 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!

...