Μετάβαση στο περιεχόμενο

Microsoft SQL Server

Από τη Βικιπαίδεια, την ελεύθερη εγκυκλοπαίδεια

Ο SQL Server (προφέρεται «σίκουελ σέρβερ») είναι μια σχεσιακή βάση δεδομένων, η οποία αναπτύσσεται από τη Microsoft. Οι κύριες γλώσσες που χρησιμοποιούνται είναι η T-SQL και η ANSI SQL. Ο SQL Server βγήκε για πρώτη φορά στην αγορά το 1989 σε συνεργασία με την Sybase.

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

Η κεντρική βάση δεδομένων του SQL υποστηρίζει διαφορετικούς τύπους, συμπεριλαμβανομένων των ακεραίων αριθμών, αριθμών κινητής υποδιαστολής, δεκαδικών, αλφαριθμητικών, Varchar (σειρές χαρακτήρων μεταβλητού μήκους), δυαδικών αριθμών (για τα μη δομημένα δεδομένα), κειμένων (για κείμενα).

Επιτρέπει επίσης καθορισμένους από το χρήστη σύνθετους τύπους δεδομένων (UDTs), δηλαδή τύπους που βασίζονται στους βασικούς τύπους αλλά μπορούν να τροποποιηθούν. Τα στοιχεία στη βάση δεδομένων αποθηκεύονται σε ένα (ή περισσότερα) αρχεία με επέκταση .mdf.

Τα δευτεροβάθμια στοιχεία αποθηκεύονται στο αρχείο με επέκταση .ndf. Το αρχείο καταγραφής το οποίο περιέχει όλες τις πρόσφατες αλλαγές στη βάση δεδομένων αποθηκεύεται σε αρχείο με επέκταση .ldf.

Ο χώρος αποθήκευσης που διατίθεται σε μια βάση δεδομένων διαιρείται σε διαδοχικά αριθμημένες σελίδες, κάθε μία από τις οποίες έχει μέγεθος 8 KB.

Οι σελίδες αποθηκεύονται στην ενδιάμεση (buffer) μνήμη RAM για να ελαχιστοποιηθεί η μεταφορά δεδομένων προς και από τον σκληρό δίσκο. Οποιαδήποτε σελίδα 8 KB μπορεί να είναι αποθηκευμένη στη μνήμη, και το σύνολο όλων των σελίδων που αποθηκεύονται σε μία περίοδο καλείται λανθάνουσα μνήμη (cache).

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

Ο κεντρικός διακομιστής SQL εξασφαλίζει ότι οποιαδήποτε αλλαγή στα στοιχεία είναι "ACID", δηλ. χρησιμοποιεί τις "συναλλαγές" (transactions) που εξασφαλίζουν ότι οποιαδήποτε λειτουργία είτε ολοκληρώνεται συνολικά είτε αποτυγχάνει συνολικά, αλλά δεν αφήνει ποτέ τη βάση δεδομένων σε μία ενδιάμεση κατάσταση.

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

Υπό αυτήν τη μορφή, θα πρέπει να ελέγξει την ταυτόχρονη πρόσβαση στα κοινά στοιχεία, για να εξασφαλίσει την ακεραιότητα των στοιχείων – Π.χ όταν πολλαπλάσιοι πελάτες ενημερώνουν τα ίδια στοιχείο, ή οι πελάτες προσπαθούν να διαβάσουν ένα στοιχείο το οποίο αλλάζεται από έναν άλλο πελάτη.

Ο κεντρικός διακομιστής SQL παρέχει δύο τρόπους ελέγχου του ταυτοχρονισμού: απαισιόδοξος ταυτοχρονισμός και αισιόδοξος ταυτοχρονισμός.

Όταν ο απαισιόδοξος έλεγχος ταυτοχρονισμού χρησιμοποιείται, ο κεντρικός διακομιστής SQL ελέγχει την ταυτόχρονη πρόσβαση με τη χρησιμοποίηση κλειδώματος (locks). Τα κλειδώματα μπορούν είτε να διαμοιράζονται είτε να είναι αποκλειστικά. Το αποκλειστικό κλείδωμα χορηγεί στο χρήστη την αποκλειστική πρόσβαση στα στοιχεία (συνήθως κατά την αλλαγή στοιχείων) - κανένας άλλος χρήστης δεν μπορεί να έχει πρόσβαση στα στοιχεία εφόσον υπάρχει κλείδωμα. Το κοινό κλείδωμα χρησιμοποιείται όταν διαβάζεται κάποιο στοιχείο - πολλαπλοί χρήστες μπορούν να διαβάσουν από τα στοιχεία που κλειδώνονται με ένα κοινό κλείδωμα, αλλά να μην αποκτούν αποκλειστικό.

Το κλείδωμα μπορεί να εφαρμοστεί σε διαφορετικά επίπεδα - σε ολόκληρους πίνακες, σελίδες ή ακόμα και σε διαφορετικές γραμμές. Το επίπεδο που χρησιμοποιείται καθορίζεται σε μια βάση δεδομένων από περίπλοκους αλγόριθμους του SQL Server, οι οποίοι έχουν σκοπό την γρηγορότερη και καλύτερη λειτουργία από χιλιάδες χρήστες η ακόμη και εκατοντάδες χιλιάδες την ίδια στιγμή. Ενας SQL Server είναι δυνατόν να πραγματοποιήσει μέχρι και 1.000.000 transactions το δευτερόλεπτο με το ανάλογο υλικό. Ο SQL Server λειτουργεί σε 32 η 64 bit και υποστηρίζει μέχρι και 256 πυρήνες (CPU) Τυπική χρήση είναι οι 8-16 επεξεργαστές.

Ανάκτηση δεδομένων

[Επεξεργασία | επεξεργασία κώδικα]
Επεξεργαστής ερώτησης σε μια ένωση 2 πινάκων

Η ερώτηση (query) είναι ο κύριος τρόπος για την ανάκτηση στοιχείων από μια βάση δεδομένων. Η ερώτηση εκφράζεται χρησιμοποιώντας μια παραλλαγή της αποκαλούμενου SQL Τ-SQL, είναι μια διάλεκτος SQL που αναπτύχθηκε από την Microsoft και Sybase. Η T-SQL είναι πολύ κοντά στα ANSI standards που έχουν καθιερωθεί διεθνώς, σε αντιδιαστολή με άλλες διαλέκτους όπως η PL-SQL της Oracle που διαφέρουν περισσότερο από το ANSI standards.

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

Υπάρχουν πολλοί τρόποι για να υποβληθεί σε επεξεργασία η ίδια ερώτηση. Π.χ, μια ερώτηση που ενώνει 2 πίνακες Α & Β μαζί θα μπορούσε να γίνει ή πηγαίνωντας πρώτα στο Α βρισκοντας τα στοιχεία και μετά ενώνοντας με τα στοιχεία του πίνακα Β, ή πρώτα από το Β και μετά πίνακα Α. Ο SQL Server και όχι ο Προγραμματιστής παίρνει την απόφαση μέσω στατιστικών στοιχείων και άλλων στοιχείων που διαθέτει για τους 2 πίνακες να ακολουθήσει την διαδρομή Α-Β γιατί αυτός είναι ο γρηγορότερος τρόπος. Στις procedural γλώσσες προγραμματισμού π.χ. C, Pascal, .NET, ο προγραμματιστής θα πρέπει να κάνει την απόφαση το οποίο πολλές φορές σημαίνει λάθος απόφαση. Αυτό καλείται βελτιστοποίηση ερώτησης και εκτελείται από τον επεξεργαστή ερώτησης. Ο SQL παίρνει πολύ περίπλοκες αποφάσεις βασισμένος σε αλγόριθμους που έχουν αναπτυχθεί τα τελευταία 20-30 χρόνια πάνω στο αντικείμενο. Μια παρόμοια ερώτηση σε μια προηγούμενη έκδοση του SQL Server θα μπορούσε να πάρει 10-20 φορές περισσότερο χρόνο λόγω του διαφορετικού αλγόριθμου. Γενικά κάθε καινούργια έκδοση βελτιώνει την αποτελεσματικότητα, και άρα τον χρόνο εκτέλεσης. Εδώ ακριβώς είναι ένα από το πλεονεκτήματα προγραμματισμού ενός προβλήματος σε μια βαση δεδομένων σε σύγκριση με C, Pascal, C++ κτλ. Βέβαια όλα τα προβλήματα δεν είναι κατάλληλα για εφαρμογή σε βάση δεδομένων.

Ο SQL Server επιτρέπει επίσης αποθηκευμένες ερωτήσεις (stored procedures). Οι αποθηκευμένες ερωτήσεις είναι ερωτήσεις με παραμέτρους T-SQL, οι οποίες αποθηκεύονται στον SQL Server. Μια stored procedure τυπικά είναι από 100-1000 γραμμές κώδικα SQL. Οι αποθηκευμένες ερωτήσεις μπορούν να δεχτούν τιμές που στέλνονται από τον πελάτη ως παράμετροι εισαγωγής, και να στείλουν τα αποτελέσματα ως παραμέτρους παραγωγής. Μπορούν να καλέσουν functions, και άλλες stored procedures. Οι stored procedures είναι γρηγορότερες από κατασκευή σε σχέση με απλές ακολουθίες SQL.

Ο Microsoft SQL Server 2005 – 2008 περιλαμβάνει ένα module (δηλαδή μονάδα μέτρησης) που λέγεται SQL CLR μέσω του οποίου ενσωματώνει τo .NET μέσα στον SQL Server.

Με το SQL CLR, οι αποθηκευμένες διαδικασίες μπορούν να γραφτούν σε οποιαδήποτε γλώσσα .NET συμπεριλαμβανομένου C# και VB.NET και να δημιουργήσουν μια stored procedure (αποθηκευμένη διαδικασία). Αυτό σημαίνει ότι ο SQL Server έχει όλες τις βιβλιοθήκες και πλεονεκτήματα του .ΝΕΤ, αυτόχθονα μέσα στο περιβάλλον του, τα οποία μπορεί να τα καλέσει οποιαδήποτε στιγμή.

Microsoft SQL Server Express Εκδόσεις 
Έκδοση Ημερομηνία Κυκλοφορίας Λήξη Υποστήριξης Εκτεταμένη λήξη Υποστήριξης Υποστηριζόμενα λειτουργικα
SQL Server 2005 Express Edition 2005-11-07[1] 2011-04-12[2] 2016-04-12[2] Windows 2000 Service Pack 4, Windows XP Service Pack 2, Windows Server 2003 Service Pack 1[3]
SQL Server 2008 Express 2009-02-08[4] 2014-07-08[5] 2019-07-09[5] Windows XP Service Pack 2, Windows XP Service Pack 3, Windows Vista, Windows Vista Service Pack 1, Windows Server 2003 Service Pack 2, Windows Server 2008[6]
SQL Server 2008 R2 Express 2010-04-16[7] 2014-07-08[8] 2019-07-09[8] Windows XP, Windows Vista, Windows 7, Windows Server 2003, Windows Server 2008, Windows Server 2008 R2
SQL Server 2012 Express 2012-05-14[9] 2017-07-11[10] 2022-07-12[10] Windows Vista Service Pack 2, Windows 7, Windows 7 Service Pack 1, Windows 8, Windows 8.1, Windows Server 2008[11], Windows Server 2008 R2, Windows Server 2008 R2 SP1, Windows Server 2012, Windows Server 2012 R2[12]
SQL Server 2014 Express 2014-04-01[13] 2019-07-09[14] 2024-07-09[14] Windows 7 Service Pack 1, Windows 8, Windows 8.1, Windows 10, Windows Server 2008 SP2[15], Windows Server 2008 R2 SP1, Windows Server 2012, Windows Server 2012 R2[16]
  • Ο Μεσίτης Υπηρεσιών (Service Broker) που τρέχει ως μέρος της μηχανής βάσεων δεδομένων, παρέχει μια αξιόπιστη πλατφόρμα μηνυμάτων και αναμονής μηνυμάτων για τις εφαρμογές κεντρικών SQL Server. Ο Service Broker έχει ανώτερες δυνατότητες προγραμματισμού στο μέλλον (scheduling). .[17]
  • Οι υπηρεσίες συγχρονίσμού (Replication) του SQL Server χρησιμοποιούνται από τον SQL Server για και να συγχρονίσουν βάσεις δεδομένων, είτε ολοκληρωτικά είτε ένα υποσύνολο των αντικειμένων. Υπάρχουν τουλάχιστον 4 διαφορετικοί μέθοδοι (log shipping, mirroring, replication, back-ups, clustering) για τον συγχρονισμό. Αυτό βοηθάει επίσης και σε περιπτώσεις ολοκληρωτικής καταστροφής της μητρικής βάσης δεδομένων, δίνοντας την δυνατότητα ακόμη και για αυτόματη λειτουργία της δευτερέυουσας συγχρονισμένης βάσης δεδομένων. [18]
  • Οι υπηρεσίες ανάλυσης (Analysis Services) SQL Server προσθέτουν τις ικανότητες OLAP και περίπλοκης ανάκτησης δεδομένων για τις βάσεις δεδομένων SQL, με περίπλοκη ανάλυση χωρίς την ανάγκη για δύσκολες SQL queries. Υποστηρίζεται το MOLAP, ROLAP και HOLAP για τα στοιχεία.[19]
  • Ο SQL Server έχει υπηρεσίες Reporting για στοιχεία που συγκεντρώνονται από τις βάσεις δεδομένων SQL Server. Με αυτόν τον τρόπο είναι δυνατό να παραχθεί μια έκθεση Ιστού (Web Report) σχεδόν αυτόματα χωρίς προγραμματισμό HTML, CSS ή JavaScript, μέσα από το Visual Studio.[20]
  • Οι υπηρεσίες ανακοίνωσης (Notification Services) δίνουν την δυνατότητα στον χρήστη να παράγει μηνύματα ηλεκτρονικού ταχυδρομείου με πολύ λίγο κόπο.[21].[22]
  • Το Integration Services του SQL χρησιμοποιούνται για να ενσωματώσουν στοιχεία από διαφορετικές πηγές δεδομένων. Χρησιμοποιεί τις ικανότητες ETL. Οι Integration Services περιλαμβάνουν εργαλεία GUI για να χτίσουν διάφορες λειτουργίες ροών δεδομένων, όπως η εξαγωγή στοιχείων από διάφορες πηγές, η συζήτηση στοιχείων, ο μετασχηματισμός των στοιχείων συμπεριλαμβανομένης της συνάθροισης, του διπλασιασμού και η συγχώνευσης.[23]
  • Ο SQL Server μπορεί επίσης να αναζητήσει μέσα σε κειμένα (Full Text Search Service ). Ο δείκτης αναζήτησης μπορεί να δημιουργηθεί σε οποιαδήποτε στήλη και έτσι η αναζήτηση πραγματοποιείται άμεσα. Για παράδειγμα, κείμενα Word και έγγραφα pdf αποθηκευμένα στον SQL Server μπορούν αναζητηθούν πολύ γρήγορα .[24]
  1. «Download Microsoft SQL Server 2005 Express Edition from Official Microsoft Download Center». Ανακτήθηκε στις 26 Δεκεμβρίου 2012. 
  2. 2,0 2,1 «Microsoft Support Lifecycle (SQL Server 2005)». Ανακτήθηκε στις 26 Δεκεμβρίου 2012. 
  3. «Microsoft SQL Server 2005 Express Edition». Microsoft Download Center. Ανακτήθηκε στις 7 Απριλίου 2017. 
  4. «Download Microsoft SQL Server 2008 Express from Official Microsoft Download Center». Ανακτήθηκε στις 26 Δεκεμβρίου 2012. 
  5. 5,0 5,1 «Microsoft Support Lifecycle (SQL Server 2008)». Ανακτήθηκε στις 26 Δεκεμβρίου 2012. 
  6. https://www.microsoft.com/en-us/download/details.aspx?id=1695
  7. «Download Microsoft SQL Server 2008 R2 - Express from Official Microsoft Download Center». Ανακτήθηκε στις 26 Δεκεμβρίου 2012. 
  8. 8,0 8,1 «Microsoft Support Lifecycle (SQL Server 2008 R2)». Ανακτήθηκε στις 26 Δεκεμβρίου 2012. 
  9. «Download Microsoft® SQL Server® 2012 Express from Official Microsoft Download Center». Ανακτήθηκε στις 26 Δεκεμβρίου 2012. 
  10. 10,0 10,1 «Microsoft Support Lifecycle (SQL Server 2012)». Ανακτήθηκε στις 26 Δεκεμβρίου 2012. 
  11. «Hardware and Software Requirements for Installing SQL Server 2012». Ανακτήθηκε στις 6 Ιουνίου 2017. 
  12. «Microsoft® SQL Server® 2012 SP2 Express». Microsoft Download Center. Ανακτήθηκε στις 7 Απριλίου 2017. 
  13. «Download Microsoft SQL Server 2014 Express». Αρχειοθετήθηκε από το πρωτότυπο στις 13 Απριλίου 2014. Ανακτήθηκε στις 11 Απριλίου 2014. 
  14. 14,0 14,1 «Microsoft Support Lifecycle (SQL Server 2014)». Ανακτήθηκε στις 11 Απριλίου 2014. 
  15. «Hardware and Software Requirements for Installing SQL Server 2014». Ανακτήθηκε στις 30 Ιουνίου 2017. 
  16. «Microsoft® SQL Server® 2014 Express». Microsoft Download Center. Ανακτήθηκε στις 8 Απριλίου 2017. 
  17. «Introducing Service Broker». Ανακτήθηκε στις 3 Δεκεμβρίου 2007. 
  18. «Types of Replication Overview». Ανακτήθηκε στις 3 Δεκεμβρίου 2007. 
  19. «Analysis Services Architecture». Ανακτήθηκε στις 3 Δεκεμβρίου 2007. 
  20. «SQL Server Reporting Services». Ανακτήθηκε στις 3 Δεκεμβρίου 2007. 
  21. «SAn Introduction to SQL Server Notification Services». Αρχειοθετήθηκε από το πρωτότυπο στις 10 Δεκεμβρίου 2008. Ανακτήθηκε στις 14 Νοεμβρίου 2008. 
  22. «SQL Server Notification Services Removed from SQL Server 2008». Αρχειοθετήθηκε από το πρωτότυπο στις 16 Οκτωβρίου 2008. Ανακτήθηκε στις 17 Σεπτεμβρίου 2008. 
  23. «Integration Services Overview». Ανακτήθηκε στις 3 Δεκεμβρίου 2007. 
  24. «Introduction to Full-Text Search». Ανακτήθηκε στις 3 Δεκεμβρίου 2007.