⊗ppPmDOGD 382 of 447 menu

Ανάκτηση δεδομένων από συσχετισμένους πίνακες σε PHP

Ας κάνουμε ένα ερώτημα που θα ανακτήσει όλους τους χρήστες μαζί με τις πόλεις τους. Για αυτό θα χρειαστούμε την εντολή LEFT JOIN:

Η σύνταξή της είναι η εξής:

SELECT πεδία FROM όνομα_πίνακα LEFT JOIN όνομα_συσχετισμένου_πίνακα ON συνθήκη_σύνδεσης WHERE συνθήκη_επιλογής

Ας αναλύσουμε τα μεμονωμένα μέρη της σύνταξης αυτής της εντολής.

Πεδία

Εφόσον η επιλογή γίνεται από πολλούς πίνακες, η επιλογή όλων των πεδίων μέσω * δεν θα λειτουργήσει. Το ακόλουθο ερώτημα θα επιλέξει πεδία μόνο από τον κύριο πίνακα, αλλά όχι από τον συσχετισμένο:

SELECT *

Για να επιλεγούν δεδομένα από όλους τους πίνακες, πρέπει πριν από το * να ορίσετε το όνομα του πίνακα για επιλογή:

SELECT users.*, cities.*

Εναλλακτικά, μπορείτε να απαριθμήσετε τα απαιτούμενα πεδία ορίζοντας το όνομα του πίνακα πριν από αυτά:

SELECT users.name, cities.name

Αυτές οι δύο μέθοδοι έχουν ένα πρόβλημα. Το γεγονός είναι ότι εάν τα πεδία στους πίνακες έχουν πανομοιότυπα ονόματα, τότε στον πίνακα PHP θα υπάρξει μια διένεξη ονομάτων και μόνο ένα πεδίο θα "κερδίσει", ενώ το δεύτερο δεν θα υπάρχει.

Για να λυθεί το πρόβλημα, τα ονόματα που βρίσκονται σε διένεξη πρέπει να μετονομαστούν μέσω της εντολής as:

SELECT users.name, cities.name as city_name

Σύνδεση

Μετά την εντολή ON πρέπει να ορίσουμε τα πεδία από τους δύο πίνακες, μέσω των οποίων πραγματοποιείται η σύνδεση. Στην περίπτωσή μας, αυτό θα είναι το πεδίο id από τον πίνακα των πόλεων και το πεδίο city_id από τον πίνακα των χρηστών:

ON cities.id=users.city_id

Ερώτημα

Τελικά, το ερώτημα που θα ανακτήσει τους χρήστες μαζί με τις πόλεις τους θα είναι το εξής:

SELECT users.name, cities.name as city_name FROM users LEFT JOIN cities ON cities.id=users.city_id

Πρακτικές Ασκήσεις

Ας υποθέσουμε ότι έχετε έναν πίνακα με προϊόντα και έναν πίνακα με τις κατηγορίες τους. Γράψτε ένα ερώτημα που θα ανακτά τα ονόματα των προϊόντων μαζί με τις κατηγορίες τους.

Ελληνικά
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Χρησιμοποιούμε cookie για τη λειτουργία του ιστότοπου, την ανάλυση και την εξατομίκευση. Η επεξεργασία των δεδομένων γίνεται σύμφωνα με την Πολιτική Απορρήτου.
αποδοχή όλων ρύθμιση απόρριψη