MySQL + Γλώσσα Προγραμματισμού

Slides:



Advertisements
Παρόμοιες παρουσιάσεις
Εισαγωγή στα Συστήματα Βάσεων Δεδομένων
Advertisements

Σχεσιακός Λογισμός Βάσεις Δεδομένων Ευαγγελία Πιτουρά.
ΕΙΣΑΓΩΓΗ ΣΤΗΝ PHP. Τι θα μάθουμε;  Να καταλάβουμε τι είναι η PHP και πώς δουλεύουν τα PHP scripts  Τι χρειάζεται για να ξεκινήσουμε με την PHP  Να.
ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ Εισαγωγή στις Βάσεις Δεδομένων για Μαθητές Λυκείων και Τεχνικών Σχολών Δημήτρης Ζεϊναλιπούρ Λέκτορας Τμήμα Πληροφορικής,
set-up on Windows 8 devices
ΕΣΔ 232: Οργάνωση Δεδομένων στη Κοινωνία της Πληροφορίας © 2013 Nicolas Tsapatsoulis Εισαγωγή στην SQL ΕΣΔ232 – Οργάνωση Δεδομένων στη Κοινωνία της Πληροφορίας.
HAMSTER Κώστα Κωνσταντίνος Ματθαίου Γιώργος Σκιττίδου Ελένη Τορτούρη Κατερίνα Advance p2p network 1/7/20141ΕΠΛ Θεμελιώσεις Τεχνολογιών Διαδικτύου.
Προχωρημένα Θέματα Τεχνολογίας και Εφαρμογών Βάσεων Δεδομένων Ασφάλεια σε Βάσεις Δεδομένων Πάνος Βασιλειάδης Σεπτέμβρης 2003
Βάσεις Δεδομένων 1 T.Manavis– N.Kyritsis.
Βάσεις Δεδομένων Ευαγγελία Πιτουρά1 Εισαγωγή στην Επεξεργασία Ερωτήσεων.
Βάσεις Δεδομένων II Ευαγγελία Πιτουρά 1 Ασφάλεια και Δικαιοδοσία σε Βάσεις Δεδομένων.
Δ.Π.Θ. Συνδέοντας έγγραφα - 1 Συνδέοντας έγγραφα Μια σύνδεση στο Web (link) αποτελείται από δύο μέρη : Aυτό που βλέπουμε στη σελίδα και λέγεται άγκυρα.
ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Πίνακες Κλάσεις και Αντικείμενα.
Databases Θ. Βαρβαρίγου Καθηγήτρια ΕΜΠ Τηλ
ΑΝΑΠΑΡΑΣΤΑΣΗ ΓΝΩΣΗΣ ΣΤΟΝ ΠΑΓΚΟΣΜΙΟ ΙΣΤΟ Jena API
Databases & Qt Μανούσης Πέτρος ΑΜ: 862
PL/SQL.
Ορισμοί Σχεσιακού Μοντέλου και (απλές)Τροποποιήσεις Σχέσεων στην SQL
Σχεδίαση-Ανάπτυξη Εφαρμογών Πληροφορικής Αντώνιος Συμβώνης, ΕΜΠ, Slide 1 Week 4: Exceptions Εβδομάδα 4: Εξαιρέσεις [Exceptions]
Πληροφοριακά Συστήματα και Βάσεις Δεδομένων
JAVA και SQL Δαμιανός Χατζηαντωνίου
ΤΕΧΝΙΚΕΣ Αντικειμενοστραφουσ προγραμματισμου
Entity-Relationship Παραδείγματα Πληροφοριακά Συστήματα και Βάσεις Δεδομένων Φροντιστήριο 1 Δαμιανός Χατζηαντωνίου.
Βάσεις Δεδομένων Ευαγγελία Πιτουρά1 Ορισμοί Σχεσιακού Μοντέλου και Τροποποιήσεις Σχέσεων.
Προγραμματισμός ΙΙ Διάλεξη #6: Απλές Δομές Ελέγχου Δρ. Νικ. Λιόλιος.
1 Προχωρημένα Θέματα Τεχνολογίας και Εφαρμογών Βάσεων Δεδομένων Επεξεργασία και βελτιστοποίηση ερωτήσεων Πάνος Βασιλειάδης Σεπτέμβρης.
Προχωρημένα Θέματα Τεχνολογίας και Εφαρμογών Βάσεων Δεδομένων Επεξεργασία και βελτιστοποίηση ερωτήσεων Πάνος Βασιλειάδης Σεπτέμβρης 2005.
ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Εισαγωγή στη Java II.
Προγραμματισμός ΙΙ Διάλεξη #5: Εντολές Ανάθεσης Εντολές Συνθήκης Δρ. Νικ. Λιόλιος.
Βάσεις Δεδομένων Εργαστήριο Ι Τμήμα Πληροφορικής ΑΠΘ
Οριζόντιο Έργο Υποστήριξης Σχολείων, Εκπαιδευτικών και Μαθητών στο Δρόμο για το ΨΗΦΙΑΚΟ ΣΧΟΛΕΙΟ, νέες υπηρεσίες Πανελλήνιου Σχολικού Δικτύου και Στήριξη.
PHP/MYSQL ΠΑΡΟΥΣΙΑΣΗ ΣΤΑ ΠΛΑΙΣΙΑ ΤΟΥ ΜΑΘΗΜΑΤΟΣ ΕΠΟΙΚΟΙΝΩΝΙΑ ΑΝΘΡΩΠΟΥ-ΜΗΧΑΝΗΣ ΤΥΡΟΛΟΓΟΥ ΓΛΥΚΕΡΙΑ ΑΜ 875 ΡΙΖΟΥ ΔΕΣΠΟΙΝΑ ΑΜ 816.
Google's Google App Engine and Google's Datastore API Andreas Manoli.
1 Εισαγωγή στη Java Χρήσιμες Διευθύνσεις Χαρακτηριστικά της Java Εργαλεία της Java Εργαλεία της Java Μεταγλώττιση στοιχειωδών εφαρμογών.
Βάσεις Δεδομένων Εργαστήριο ΙΙI Τμήμα Πληροφορικής ΑΠΘ
Βάσεις Δεδομένων Ευαγγελία Πιτουρά1 Ορισμοί Σχεσιακού Μοντέλου και Τροποποιήσεις Σχέσεων σε SQL.
ΕΛΛΗΝΙΚΟ ΑΝΟΙΚΤΟ ΠΑΝΕΠΙΣΤΗΜΙΟ Διασύνδεση Java Εφαρμογών με ΒΔ Π. Φιτσιλής 1.
ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Γενικευμένες κλάσεις Συλλογές.
Βάσεις Δεδομένων Εργαστήριο ΙΙ Τμήμα Πληροφορικής ΑΠΘ
Βάσεις Δεδομένων Ευαγγελία Πιτουρά1 Σχεσιακός Λογισμός.
1 Βάσεις Δεδομένων ΙI Επιμέλεια: ΘΟΔΩΡΗΣ ΜΑΝΑΒΗΣ SQL (3 από 3) T Manavis.
9 Η Γλώσσα SQL  Εισαγωγή – Βασικές Έννοιες  Τύποι Δεδομένων  Ορισμός Δεδομένων (data definition)  Χειρισμός Δεδομένων (data manipulation)
Copyright © 2006 – Quality & Reliability SA PL/SQL TRIGGERS ΜΕΡΟΣ 1.
Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1 Σχεσιακός Λογισμός.
Κουλίνας Μιχαήλ Α.Μ.:774 Μπουρνάζης Χρήστος Α.Μ.:792 Ρογκάκος Γεώργιος Α.Μ.:817.
Εγκατασταση & ρυθμισεισ
Πανεπιστήμιο Κύπρου – Τμήμα Πληροφορικής ΕΠΛ446-Προχωρημένες Βάσεις Δεδομένων Ζωγραφάκης Ιωάννης.
Tomcat Θ. Βαρβαρίγου Καθηγήτρια ΕΜΠ Τηλ
1 26/6/2015 Προγραμματισμός Διαδικτύου – Lecture 8 LECTURE 8 Using Databases with PHP Scripts: Using MySQL Database with PHP Προγραμματισμός Διαδικτύου.
Βάσεις Δεδομένων II (Θ) Ενότητα 10: Μελέτη περίπτωσης: Χρήση JDBC API, JSP pages Χ. Σκουρλάς Τμήμα Μηχανικών Πληροφορικής ΤΕ Ανοικτά Ακαδημαϊκά Μαθήματα.
Ενότητα 1 : Το σύστημα βάσεων δεδομένων MySQL (1) Ιωάννης Τσούλος
Βάσεις Δεδομένων και Ευφυή Πληροφοριακά Συστήματα Επιχειρηματικότητας
Σκοπός Μαθήματος Σκοπός: Παρουσιάζεται η διαχείριση βάσης δεδομένων με γλώσσα SQL, χρήση JDBC API, και τεχνολογίας JSP pages και λογισμικού mySQL. Στόχος.
Σκοπός Μαθήματος Σκοπός: Παρουσιάζεται η διαχείριση βάσης δεδομένων με γλώσσα SQL, χρήση JDBC API, και τεχνολογίας JSP pages και λογισμικού mySQL. Στόχος.
Βάσεις Δεδομένων Ι 4η διάλεξη
Ασκήσεις στην Java-XML
Σκοπός Μαθήματος Σκοπός: Παρουσιάζεται η διαχείριση βάσης δεδομένων με γλώσσα SQL, χρήση JDBC API, και τεχνολογίας JSP pages και λογισμικού mySQL. Στόχος.
Θερινό Σχολείο, 14 – 20 Ιουλίου 2014
Έλεγχος λογισμικού Ποιότητα Λογισμικού Black Box testing
Java DataBase Connectivity
9 Η Γλώσσα SQL Εισαγωγή – Βασικές Έννοιες Τύποι Δεδομένων
Ορισμοί Σχεσιακού Μοντέλου και Τροποποιήσεις Σχέσεων σε SQL
Βάσεις Δεδομένων Κωδικός Μαθήματος: MK741
Βάσεις Δεδομένων Κωδικός Μαθήματος: MK741
ΠΑΝΕΠΙΣΤΗΜΙΟ ΙΩΑΝΝΙΝΩΝ ΑΝΟΙΚΤΑ ΑΚΑΔΗΜΑΪΚΑ ΜΑΘΗΜΑΤΑ
Ανοικτά Ακαδημαϊκά Μαθήματα στο ΤΕΙ Αθήνας
Βάσεις Δεδομένων ΙΙ (SQL error diagnostics), δήλωση Get Diagnostics
Διασύνδεση με ΒΔ Web Server Database MySQL MSSQL Oracle PostgreSQL
Databases Θ. Βαρβαρίγου Καθηγήτρια ΕΜΠ Τηλ
ΠΑΡΑΔΕΙΓΜΑΤΑ SQL Ή ΠΑΡΑΔΕΙΓΜΑΤΑ SQL Ή
Μεταγράφημα παρουσίασης:

MySQL + Γλώσσα Προγραμματισμού Βάσεις Δεδομένων 2013-2014 Ευαγγελία Πιτουρά

Database drivers Για να χρησιμοποιήσουμε μια βάση δεδομένων από μια γλώσσα προγραμματισμού χρειαζόμαστε έναν “driver”. JDBC είναι το API για τη Java και καθορίζει πως ένας πελάτης μπορεί να συνδεθεί με μια βάση δεδομένων Σύνδεση με τη βδ, εκτέλεση ερωτήσεων και τροποποιήσεων και συλλογή των αποτελεσμάτων Τεχνικά: είναι ένα σύνολο από κλάσεις στο java.sql package. Υπάρχει ένα JDBC για κάθε διαφορετικό ΣΔΒΔ Για τη MySQL: Connector/J  Για MySQL και C++: Connector/C++  Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Βήμα 0: Εγκατάσταση του driver (Connector/J) Κατεβάστε Connector/J using binary distribution από: http://dev.mysql.com/downloads/connector/j/5.0.html Εγκατάσταση: unzip (or untar) και θέστε το mysql-connector-java-[version]-bin.jar στο class path Αν χρησιμοποείτε Netbeans IDE, υπάρχει ήδη Οδηγίες: «Inside the Projects tab, right click on the Libraries node and select Add Library option. From the list of options, select MySQL JDBC Driver.» Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Παράδειγμα mysql> CREATE DATABASE testdb; Query OK, 1 row affected (0.02 sec) Δημιουργούμε μια βάση δεδομένων Φτιάχνουμε ένα νέο χρήστη και του δίνουμε δικαιώματα σε όλους τους πίνακες της testdb mysql> CREATE USER 'testuser'@'localhost' IDENTIFIED BY 'test623‘; Query OK, 0 rows affected (0.00 sec) mysql> USE testdb; Database changed mysql> GRANT ALL ON testdb.* TO 'testuser'@'localhost'; Query OK, 0 rows affected (0.00 sec) Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Παράδειγμα Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Σύνδεση με τη βάση δεδομένων package name.mysql.first; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Σύνδεση με τη βάση δεδομένων Connection con = null; String url = "jdbc:mysql://localhost:3306/testdb"; String user = "testuser"; String password = "test623"; con = DriverManager.getConnection(url, user, password); url = "jdbc:mysql://localhost:3306/testdb Host Port όνομα βδ Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Εκτέλεση SQL εντολών στη βδ Η μέθοδος  createStatement() του connection object δημιουργεί ένα  Statement object για να στέλνουμε SQL εντολές στη βάση δεδομένων Statement st = null; st = con.createStatement(); Για να εκτελέσουμε SQL εντολές Ερωτήσεις (select queries) Τροποποιήσεις (insert, update deletes) rs = st.executeQuery(query); st.executeUpdate(query); Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Τροποποίηση Η εκτέλεση της εντολής δεν επιστρέφει αποτελέσματα Statement st = null; st = con.createStatement(); String query = "INSERT INTO Authors(Id, Name) VALUES(6, ‘Steven King'); st.executeUpdate(query); Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Ερώτηση Η εκτέλεση της εντολής επιστρέφει αποτελέσματα. Τα αποτελέσματα εισάγονται σε ένα ResultSet object – ένας πίνακας Statement st = null; ResultSet rs = null; st = con.createStatement(); String query = "SELECT * FROM Authors"; rs = pst.executeQuery(query); pst.close(); Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Ερώτηση: Cursor Τα δεδομένα από το ResultSet διαβάζονται μια πλειάδα (γραμμή, εγγραφή) τη φορά H μέθοδος next() προχωρά το δείκτη (cursor) στην επόμενη εγγραφή Επιστρέφει null όταν δεν υπάρχουν άλλες πλειάδες Statement st = null; ResultSet rs = null; st = con.createStatement(); String query = "SELECT * FROM Authors"; rs = pst.executeQuery(query); pst.close(); while (rs.next()) { System.out.print(rs.getInt(1)); System.out.print(": "); System.out.println(rs.getString(2)); } Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Prepared Statements Αντί να γράφουμε μέσα στην SQL έκφραση τις πραγματικές τιμές χρησιμοποιούμε placeholder (?) Προσδιορίζουμε τις τιμές αργότερα PreparedStatement pst = null; ResultSet rs = null; String author = "Trygve Gulbranssen"; pst = con.prepareStatement("INSERT INTO Authors(Name) VALUES(?)") Προσδιορισμός τιμής pst.setString(1, author); pst.executeUpdate(); pst.close(); Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Περισσότερες πηγές Στο παρακάτω link μπορείτε να δείτε ένα ολοκληρωμένο πρόγραμμα Java http://www.cs.uoi.gr/~pvassil/courses/db_III/exercises/JavaExamples/Simple/Example1.java Επίσης: http://zetcode.com/db/mysqljava/ Οnline documentation : http://dev.mysql.com/doc/refman/5.0/en/connector-j.html Ευαγγελία Πιτουρά Βάσεις Δεδομένων 2013-2014

Ερωτήσεις; Βάσεις Δεδομένων 2013-2014 Ευαγγελία Πιτουρά