Ο τελεστής SQL OR μπορεί να βελτιστοποιήσει την αναζήτηση εγγραφών, περιορίζοντας τα αποτελέσματα σε εκείνα που πληρούν τουλάχιστον μία από τις συνθήκες σας. Μπορείτε να τον συνδυάσετε με άλλους λογικούς τελεστές, όπως AND και NOT, για να επιταχύνετε και να βελτιώσετε σύνθετα ερωτήματα.

Τι είναι το SQL OR;

Οι τελεστέςAND, NOT και ORτης SQL είναι μερικοί από τους πιο σημαντικούς τελεστές της SQL για την αναζήτηση σχετικών πληροφοριών. Ενώ AND εντοπίζει δεδομένα που πληρούν δύο ή περισσότερες συνθήκες και NOT καθορίζει τα κριτήρια που πρέπει να εξαιρούνται από τα αποτελέσματα, OR επιτρέπει πιο ευέλικτες αναζητήσεις. Σας δίνει τη δυνατότητα να ορίσετε διάφορα κριτήρια αναζήτησης, εκ των οποίων τουλάχιστον ένα πρέπει να πληρούται από τα αποτελέσματα. Το πλεονέκτημα είναι ότι μπορείτε να λάβετε σχετικά αποτελέσματα που δεν πληρούν απαραίτητα όλα τα αναφερόμενα κριτήρια.

Δεδομένου ότι η SQL OR χρησιμοποιείται για τη διατύπωση κριτηρίων αναζήτησης, συχνά συνδυάζεται με τις εντολές SELECT και WHERE. SELECT προσδιορίζει τις σχετικές εγγραφές και στήλες, ενώ WHERE καθορίζει τα κριτήρια αναζήτησης. Για να κάνετε το ερώτημα αναζήτησής σας ακόμα πιο ακριβές, μπορείτε να συνδυάσετε OR με άλλους λογικούς τελεστές, όπως AND και NOT, ή με τελεστές σύγκρισης, όπως =.

Ποια είναι η διαφορά μεταξύ των εκδόσεων SQL OR, AND και NOT;

Ακολουθούν οι διαφορές μεταξύ των εκδόσεων SQL OR, AND και NOT:

SQL OR SQL AND SQL NOT
Φιλτράρει εγγραφές που ικανοποιούν τουλάχιστον μία από τις συνθήκες Φιλτράρει δεδομένα που ικανοποιούν όλες τις συνθήκες Παραλείπει πληροφορίες που δεν ικανοποιούν μια συνθήκη
Επεκτείνει την αναζήτηση με διαφορετικές πληροφορίες Περιορίζει την αναζήτηση σε έναν συνδυασμό προϋποθέσεων, οι οποίες πληρούνται και οι δύο Παραλείπει άσχετες πληροφορίες χρησιμοποιώντας κριτήρια αποκλεισμού
Tip

Δεν έχετε γνώσεις SQL; Κανένα πρόβλημα! Η εισαγωγή μας στο SQL με παραδείγματα προσφέρει ένα εντατικό μάθημα για τα βασικά.

Ποια είναι η σύνταξη της SQL OR;

Η βασική σύνταξη της OR έχει ως εξής:

SELECT  *
FROM  Table
WHERE  condition1  OR  condition2  OR …
sql

Χρησιμοποιεί τις ακόλουθες παραμέτρους:

  • SELECT: Επιλέγει τις στήλες από τις οποίες θέλετε να ανακτήσετε δεδομένα, χρησιμοποιώντας πρωτεύοντα και ξένα κλειδιά. Μπορείτε να χρησιμοποιήσετε τον αστερίσκο * για να επιλέξετε όλες τις στήλες.
  • FROM: Καθορίζει σε ποιον πίνακα θέλετε να πραγματοποιήσετε την αναζήτηση.
  • WHERE: Ορίζει τις συνθήκες αναζήτησης χρησιμοποιώντας τελεστές και άλλες παραμέτρους.
  • OR: Λογικός τελεστής που χρησιμοποιείται με WHERE για τον καθορισμό κριτηρίων αναζήτησης.

Μπορείτε επίσης να συνδυάσετε OR, NOT και AND στην αναζήτησή σας για να περιορίσετε περαιτέρω τα αποτελέσματα.

SQL OR σε συνδυασμό με AND

Σε αυτό το παράδειγμα, η πρόταση WHERE φιλτράρει τα αποτελέσματα στα οποία ισχύει τόσο η συνθήκη 1 όσο και τουλάχιστον μία από τις συνθήκες 2 ή 3.

SELECT  *
FROM  Table
WHERE  condition1 AND (condition2 OR condition3)
sql

SQL OR σε συνδυασμό με το SQL NOT

Μπορείτε να συνδυάσετε τις συνθήκες SQL OR και NOT για να εξαιρέσετε τα δεδομένα που πληρούν τουλάχιστον μία από τις αναφερόμενες συνθήκες.

SELECT  *
FROM  Table
WHERE  NOT  (condition1  OR  condition2)
sql

Σε ποιες περιπτώσεις μπορεί να χρησιμοποιηθεί το SQL OR;

Μπορείτε να χρησιμοποιήσετε τον τελεστή SQL OR για να πραγματοποιήσετε αναζήτηση σε σύνθετα σύνολα δεδομένων με βάση πολλαπλά κριτήρια. Ακολουθούν μερικές περιπτώσεις χρήσης:

  • Φιλτράρισμα δεδομένων πελατών, παραγγελιών και προϊόντων με βάση συνδυαστικά κριτήρια αναζήτησης, όπως κατηγορίες προϊόντων, χαρακτηριστικά προϊόντων ή ημερομηνίες παραγγελιών και παραπόνων
  • Αναζήτηση εταιρειών σε συγκεκριμένους κλάδους ή περιοχές
  • Φιλτράρισμα ύποπτων ή μη έγκυρων συναλλαγών χρησιμοποιώντας πολλαπλές συνθήκες
  • Αναζήτηση πληροφοριών για υπαλλήλους από συγκεκριμένο τμήμα ή ομάδα
  • Ανάκτηση υποψηφίων που δεν διαθέτουν πτυχίο ή εργασιακή εμπειρία

Παραδείγματα SQL OR

Ο τελεστής OR έχει αμέτρητες εφαρμογές όταν συνδυάζεται με WHERE, άλλους τελεστές SQL και άλλες συναρτήσεις SQL. Παρακάτω θα δούμε 3 παραδείγματα, ώστε να αποκτήσετε μια καλύτερη εικόνα για το πώς λειτουργεί OR.

Αναζήτηση παραγγελιών από συγκεκριμένες κατηγορίες

Ας υποθέσουμε ότι θέλετε να αναζητήσετε στον πίνακα πελατών άτομα που έχουν παραγγείλει προϊόντα από μία ή και τις δύο κατηγορίες «Ηλεκτρονικά» και «Μαλλιά». Τα αποτελέσματα θα περιλαμβάνουν μόνο εγγραφές που πληρούν τουλάχιστον μία από τις δύο προϋποθέσεις. Θα χρησιμοποιήσουμε τον τελεστή σύγκρισης = για να καθορίσουμε τις κατηγορίες.

Η σύνταξη για αυτό έχει ως εξής:

SELECT  *
FROM  Customers
WHERE  (Category  =  'Electronics'  OR  Category =  'Hair')
sql

Φιλτράρισμα υποψηφίων

Σε αυτό το παράδειγμα, υπάρχει ένας πίνακας με το όνομα «Applicants». Θέλουμε να βρούμε τα άτομα που περιλαμβάνονται σε αυτόν και διαθέτουν πτυχίο ηλεκτρολόγου μηχανικού ή πληροφορικής και έχουν τουλάχιστον τρία χρόνια εργασιακής εμπειρίας. Για να το κάνουμε αυτό, θα συνδυάσουμε τις παραμέτρους OR και AND. Η αναζήτηση έχει ως εξής:

SELECT  *
FROM  Applicants
WHERE  (Degree  =  'Electrical engineering'  OR  Degree  =  'IT')
AND (Experience  >=  3)
sql

Αναζήτηση ανά περιοχή

Στο τελευταίο μας παράδειγμα, θέλουμε να αναζητήσουμε πελάτες από τη Γαλλία ή τη Γερμανία σε έναν πίνακα με το όνομα «Πελάτες». Η σύνταξη για αυτό έχει ως εξής:

SELECT  *
FROM  Customers
WHERE  Country  =  'France'  OR   Country  =  'Germany'
sql

Υπάρχουν εναλλακτικές λύσεις για το SQL OR;

Ο τελεστής OR προσφέρει έναν απλό και γρήγορο τρόπο αναζήτησης με βάση διάφορες συνθήκες. Αυτοί οι τελεστές SQL εξυπηρετούν παρόμοιο σκοπό:

  • CASE: Η έκφραση CASE της SQL μπορεί επίσης να χρησιμοποιηθεί με τις ρήτρες WHERE, THEN και ELSE για τον έλεγχο συνθηκών και τον περιορισμό σύνθετων αναλύσεων στα σχετικά αποτελέσματα. Η αξιολόγησή της γίνεται μέσω μιας δήλωσης «IF-THEN-ELSE» και εξετάζει τις συνθήκες από κάτω προς τα πάνω. Η ανάλυση διακόπτεται όταν πληρούται μία από τις συνθήκες.
  • IN: Ο τελεστής IN μπορεί να χρησιμοποιηθεί σε μια ρήτρα WHERE για την εξέταση εγγραφών. Μπορείτε να ορίσετε τιμές ή συμβολοσειρές χρησιμοποιώντας IN και στη συνέχεια να αναζητήσετε αντιστοιχίες σε πίνακες ή στήλες.
  • EXISTS: Το EXISTS της SQL μπορεί να χρησιμοποιηθεί σε έναν πίνακα για να ελέγξει αν τουλάχιστον μία εγγραφή από έναν άλλο πίνακα ταιριάζει με τον πρώτο πίνακα. Αν υπάρχει τουλάχιστον μία αντιστοιχία, το αποτέλεσμα θα προστεθεί στον πίνακα προορισμού. Αυτός ο τελεστής είναι χρήσιμος μόνο αν εργάζεστε με δύο σχετικούς πίνακες.
Go to Main Menu