Java Database Connectivity-API (JDBC)
|
|
- Brit Vogel
- vor 5 Jahren
- Abrufe
Transkript
1 Java Database Connectivity-API (JDBC) Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 1
2 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 2
3 Motivation (1/2) Problem: Zugriff auf ein DBMS ist Herstellerabhängig Anwendung Anwendung MySQL API DB2 API MySQL DB2 Anwendung Oracle API Oracle Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 3
4 Motivation (2/2) Lösung: Zwischenschicht MySQL API MySQL Anwendung JDBC API JDBC DB2 API DB2 Oracle API Oracle JDBC Treiber Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 4
5 Entwicklung Entwicklung seit: 1995 Erster Ansatz: Java erweitern Zweiter Anzatz: Treiber der Datenbankhersteller Vorbild: ODBC Unterschiede: ODBC wenige Befehle, viele Optionen JDBC viele einfache Methoden ODBC nutzt void-zeiger Java kennt keine Zeiger Flexibilität: JDBC erlaubt beliebige SQL-Statements (Zeichenfolgen) Anpassung an Datenbank möglich - Optimierung - Bindung Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 5
6 Architektur Java Anwendung JDBC-Treibermanager JDBC/ODBC -Brücke JDBC- Treiber ODBC- Treiber Datenbank Datenbank Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 6
7 Treiber (1/2) Typ 1: JDBC/ODBC-Brücke ODBC ist sehr weit verbreitet Leistung JDBC- Wartung Anwendung Testen, Experimentieren kein eigener JDBC-Treiber notwendig Client Windows Plattformen Brücke ODBC DB Server Typ 2: Partial Java Driver konvertiert JDBC-Aufruf in DB-abhängigen API-Aufruf schnell, weil API-Aufruf kompiliert ist abhängig von DB + OS JDBC- Client braucht plattformabhängige API Anw. A P I DB Client Server Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 7
8 Treiber (2/2) Typ 3: Reiner Java Treiber zu Middleware Keine plattformabhängigen Treiber am Client DB-unabhängig Flexibel, mehrere DB möglich JDBC- Anw. DB-abhängiger Code in Middleware M W DB Client Server Server Typ 4: Reiner Java Treiber direkt zur DB JDBC in DB-spezifische Netzwerkaufrufe verpackt Schnell Keine plattformabhängigen Treiber am Client Client braucht für verschiedene DB verschiedene Treiber JDBC- Anw. Client DB Server Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 8
9 Treiberinstallation Download Datenbankhersteller Installation Eintragen in den Klassenpfad Registrieren bei Anwendung Bei dem Programmstart durch Parameter: java Djdbc.drivers=com.mysql.jdbc.Driver <Programm> Setzen der Systemeigenschaft "jdbc.drivers": System.setProperty("jdbc.drivers", com.mysql.jdbc.driver"); Händisches Instanzieren der Treiber-Klasse: Class.forName("com.mysql.jdbc.Driver"); Achtung: Ab Version Java 6 nicht mehr nötig! Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 9
10 Vorgehen Typisch sind folgende Schritte: 1) Aufbau einer Verbindung zur Datenbank 2) Definition und ausführen von Datenbankkommandos 3) Verarbeiten der Ergebnisse 4) Ressourcen freigeben und Verbindung schließen 1.) Verbindung deklarieren; try { 1.) Verbindung zur Datenquelle anfordern 2.) SQL-Kommandos ausführen 3.) Ergebnis verarbeiten 4.) Ressourcen freigeben } catch ( SQLException ) { Exception behandeln } finally { try { 4.) Verbindung schließen } catch (Exception) { Exception behandeln } } Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 10
11 Klassen für Schritt 1) und 4) Driver und DriverManager Connection DataSource für Schritt 2) Statement PreparedStatement CallableStatement für Schritt 3) ResultSet Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 11
12 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 12
13 Verbindungsaufbau Verbindungsaufbau erfolgt mit Url zur Datenbank Benutername, Passwort Datenbank Url jdbc:<datenbanktreiber>:<treiberspezifische Angaben> Beispiele: MySql: jdbc:mysql://<host>:<port>/< Datenbankname> JavaDB (Derby): jdbc:derby:/path/to/database jdbc:derby:database Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 13
14 DriverManager (1/2) static-methoden zur Verwaltung der Treiber, Verbindungsaufbau, Settings Treiberverwaltung static void registerdriver(driver driver) throws SQLException static void deregisterdriver(driver driver) throws SQLException static Enumeration<Driver> getdrivers() Registrierung erfolgt üblicherweise im static-initializers der Driver-Klasse; es reicht daher, wenn Driverklasse geladen wird. Beispiel: Registrieren des Treibers druch Laden der Driver-Klasse */ Class.forName("com.mysql.jdbc.Driver").newInstance(); Achtung: Ab Version Java 6 nicht mehr nötig! Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 14
15 DriverManager (2/2) Verbindungsaufbau mit Url und optional Benutzer und Passwort liefert Connection-Objekt static Connection getconnection(string url, String user, String password) throws SQLException static Connection getconnection(string url) throws SQLException Beispiel: String url = "jdbc:odbc:wombat"; Connection con = DriverManager.getConnection(url,"oboy","12Java"); Settings: LogStream und Timeout static void setlogwriter(printwriter out) static PrintWriter getlogwriter() static void println(string message) public static void setlogintimeout(int seconds) Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 15
16 Connection Connection ist zentrales Objekt für Verbindung zur Datenbank Erzeugen von Statement-Objekten Statement createstatement() throws SQLException PreparedStatement preparestatement(string sql) throws SQLException CallableStatement preparecall(string sql) throws SQLException Zugriff auf Datenbankinformationen (Metadaten) DatabaseMetaData getmetadata() throws SQLException Transaktionen (lokale) void commit() throws SQLException void rollback() throws SQLException void setautocommit(boolean autocommit) throws SQLException Diverse Settings void setreadonly(boolean readonly) throws SQLException void settransactionisolation(int level) throws SQLException void setholdability(int holdability) throws SQLException Schließen void close() throws SQLException Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 16
17 Beispiel Verbindungsaufbau public static void main(string[] args) { String url = "jdbc:derby:c:/derby/test;create=true"; Connection conn = null; try { conn = DriverManager.getConnection(url); } } catch (SQLException e) { e.printstacktrace(); } finally { try { conn.close(); } catch (Exception e) { e.printstacktrace(); } } Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 17
18 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 18
19 Erzeugen von Statement-Objekten Es gibt 3 Arten von Statement-Objekten Statement: normale Anweisungen PreparedStatement: vorkompilierte Statements mit Input-Parametern CallableStatement: zur Ausführung von StoredProcedures mit Input- und Output-Parametern Statement-Objekte werden durch Connection erzeugt Statement createstatement() throws SqlException Statement createstatement(int resultsettype, int resultsetconcurrency) throws SQLException PreparedStatement preparestatement(string sql) throws SQLException PreparedStatement preparestatement(string sql, int resultsettype, int resultsetconcurrency, int resultsetholdability) throws SQLException CallableStatement preparecall(string sql) throws SQLException CallableStatement preparecall(string sql, int resultsettype, int resultsetconcurrency, int resultsetholdability) throws SQLException; Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 19
20 Ausführen von Statement-Objekten Statement-Objekte erlauben die Ausführung von SQL-Anweisungen SQL-Anweisungen werden als Strings übergeben 3 Methoden zur Ausführung: ResultSet executequery(string sql) throws SQLException Ausführung von SELECT-Statements liefert ResultSet als Ergebnis int executeupdate(string sql) throws SQLException Ausführung von UPDATE, INSERT, DELETE, CREATE, Ergebnis ist die Anzahl der geänderten Zeilen boolean execute(string sql) throws SQLException Ausführung von Anweisungen mit mehreren Resultaten liefert true, wenn Ergebnis ResultSet ist Zugriff auf Ergebnisse mit: ResultSet getresultset() throws SQLException boolean getmoreresults() throws SQLException Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 20
21 PreparedStatement PreparedStatement sind vorkompilierte Statements (effizienter) werden mit SQL-Anweisung durch Connection erzeugt PreparedStatement preparestatement(string sql) throws SQLException; können Input-Parameter haben werden mit? im SQL-String gekennzeichnet und identifiziert durch Position "INSERT INTO test VALUES (?)"; Setzen mit set-operationen entsprechenden Typs void set<type>(int n, <Type> x) - Setzen des Parameters an der Stelle n (1.. m). Löschen aller Parameterwerte. void clearparameters() Beispiel: PreparedStatement stat; stat = con.preparestatement("insert INTO test VALUES (?)"); stat.setstring(1, "Hallo"); stat.executeupdate(); stat.setstring(1, "Welt!"); stat.executeupdate(); Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 21
22 CallableStatement CallableStatement: Ausfüren von Datenbankprozeduren (SQL stored procedures SQL-Strings stellen Prozeduraufruf dar: Parameterlose Prozedur {call procedure_name} Prozedur: {call procedure_name[(?,?,...)]} Funktion: {? = call procedure_name[(?,?,...)]} Das Setzen der Parameter erfolgt analog zu den PreparedStatements Output-Parameter müssen als solche registriert werden void registeroutparameter(int parameterindex, int sqltype) throws SQLException Werte können mit get-methoden ausgelesen werden <Type> get<type>(int parameterindex) throws SQLException Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 22
23 Beispiel Statement und PreparedStatement public static void main(string[] args) { try { java.sql.statement stmt = conn.createstatement(); stmt.executeupdate( "create table Person (id INTEGER PRIMARY KEY, firstname VARCHAR(128), " + "lastname VARCHAR(128), born INTEGER)"); PreparedStatement pstmt = conn.preparestatement("insert into Person values(?,?,?,?)"); pstmt.setint(1, 1); pstmt.setstring(2, "Hermann"); pstmt.setstring(3, "Maier"); pstmt.setint(4, 1971); pstmt.executeupdate(); pstmt.setint(1, 2); pstmt.setstring(2, "Michael"); pstmt.setstring(3, "Walchhofer"); pstmt.setint(4, 1977); pstmt.executeupdate(); stmt.execute("update Person set born=1973 where id=1"); ResultSet rs = stmt.executequery("select id, lastname, born from Person"); } catch (SQLException e) { Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 23
24 Beispiel ResultSet Wie viele Zeilen hat ein ResultSet? Connection con;... Statement stat = con.createstatement(); ResultSet result = stat.executequery("select..."); int rowamount; result.last(); rowamount = result.getrow(); result.beforefirst(); // Mit ResultSet arbeiten while (result.next()) {... } Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 24
25 Batch-Updates Absetzen mehrerer Update-Kommandos in einem Batch zur Verbesserung der Performanz Kommandos werden mit void addbatch(string sqlcmd) void addbatch() angefügt und mit int[] executebatch() ausgeführt (Rückgabewert sind Anzahl der geänderten Zeilen pro Update) Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 25
26 Beispiel Batch-Updates mit Statement Statement stmt = conn.createstatement(); stmt.addbatch("insert into Person values(5, 'Mario', 'Scheiber', 1983)"); stmt.addbatch("insert into Person values(6, 'Rainer', 'Schönfelder', 1977)"); int[] upds = stmt.executebatch(); mit PreparedStatement PreparedStatement pstmt = conn.preparestatement("insert into Person values(?,?,?,?)"); pstmt.setint(1, 6); pstmt.setstring(2, "Mario"); pstmt.setstring(3, "Scheiber"); pstmt.setint(4, 1983); pstmt.addbatch(); pstmt.setint(1, 7); pstmt.setstring(2, "Rainer"); pstmt.setstring(3, "Schönfelder"); pstmt.setint(4, 1977); pstmt.addbatch(); int[] upds = pstmt.executebatch(); Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 26
27 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 27
28 ResultSet ResultSet stellt die Ergebnistabelle einer Abfrage dar Es gibt 3 Arten von ResultsSets einfache: können nur sequentiell von vorne nach hinten durchlaufen werden scrollbare: erlaubt beide Richtungen und Positionierung scrollbare und änderbare: erlauben auch Updates Unterscheidung erfolgt beim Erzeugen des Statements: Statement createstatement(int resultsettype, int resultsetconcurrency) throws SQLException ResultSet.TYPE_FORWARD_ONLY ResultSet.TYPE_SCROLL_INSENSITIVE ResultSet.TYPE_SCROLL_SENSITIVE ResultSet.CONCUR_READONLY ResultSet. CONCUR_UPDATABLE ResultSet.TYPE_FORWARD_ONLY ResultSet.TYPE_SCROLL_INSENSITIVE ResultSet.TYPE_SCROLL_SENSITIVE ResultSet.CONCUR_READONLY ResultSet. CONCUR_UPDATABLE - einfacher ResultSet, nur lesend - scrollbar, nur lesend - scrollbar, erlaubt updates - nur lesend - erlaubt updates Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 28
29 Sequentieller Zugriff ResultSet arbeitet mit Cursor auf aktuelle Zeile Zugriff mit get-methoden auf Spaltenwerte der aktuellen Zeile Weiterschalten auf nächste Zeile mit next boolean next() - Anspringen der nächsten Zeile (begonnen wird vor der ersten Zeile) - true solange noch eine gültige Zeile erreicht wurde. Beispiel: Typ> get<type>(int spalte) <Typ> get<type>(string spaltenname) int findcolumn(string spaltenname) getstring(3) => 25 getstring("name") => Max findcolumn("nr") => 1 next() Nr Name Max Kurt... Age Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 29
30 Beispiel ResultSet public static void main(string[] args) { try { ResultSet rs = stmt.executequery("select id, lastname, born from Person"); while (rs.next()) { int nr = rs.getint(1); String lastname = rs.getstring("lastname"); int born = rs.getint("born"); System.out.println(nr + ": " + lastname + " born: " + born); } } } catch (SQLException e) { } Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 30
31 Zugriff mit scrollable ResultSets boolean first() - Erste Zeile im ResultSet. - true wenn eine gültige Zeile erreicht wurde. beforefirst() - Vor die erste Zeile im ResultSet. boolean last() - Letzte Zeile im ResultSet. - true wenn eine gültige Zeile erreicht wurde. afterlast() - Nach letzter Zeile im ResultSet. boolean absolute(int row) - Eine Zeile anspringen row > 0... von oben gezählt (1 erste Zeile, 2 zweite Zeile,...) row < 0... von unten gezählt (-1 letzte Zeile, -2 vorletzte Zeile,...) - true wenn eine gültige Zeile erreicht wurde. boolean relative(int rows) - Überspringen von rows Zeilen int getrow() - Nummer der aktuellen Zeile int getrow() - Springen auf die vorherige Zeile Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 31
32 Beispiel scrollable ResultSet Statement scrstmt = conn.createstatement(resultset.type_scroll_insensitive, ResultSet.CONCUR_READ_ONLY); ResultSet scrrs = scrstmt.executequery("select id, lastname, born from Person"); // put out rows after 2nd scrrs.absolute(2); while (scrrs.next()) { int nr = scrrs.getint(1); String lastname = scrrs.getstring("lastname"); int born = scrrs.getint("born"); System.out.println(nr + ": " + lastname + " born: " + born); } // put out rows in reverse order scrrs.afterlast(); while (scrrs.previous()) { int nr = scrrs.getint(1); String lastname = scrrs.getstring("lastname"); int born = scrrs.getint("born"); System.out.println(nr + ": " + lastname + " born: " + born); } Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 32
33 Updates mit ResultSet ResultSets und zugrundeliegende Datenquelle kann geändert werden Änderbare ResultSets erzeugt durch createstatement mit Statement stmt = con.createstatement( ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); Änderunungen im ResultSet mit update-methoden (in aktueller Zeile) void update<type>(int column, <Type> val) void update<type>(string colname, <Type> val) Änderungen in Datenbank mit updaterow() um Änderung in aktueller Zeile in Datenquelle zu schreiben deleterow() um aktuelle Zeile zu löschen insertrow() um neue Zeile anzufügen Anfügen von neuen Zeilen Springen auf spezielle Zeile mit movetoinsertrow() Datenänderungen mit Updates Einfügen mit insertrow() rs.movetoinsertrow(); rs.updateint(2, 3857); rs.insertrow(); Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 33
34 Beispiel Update bei ResultSets Statement updstmt = conn.createstatement( ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); ResultSet updrs = updstmt.executequery("select id,firstname,lastname,born from Person"); updrs.absolute(3); while (updrs.previous()) { int born = updrs.getint("born"); // decrease born by 1 updrs.updateint("born", born - 1); updrs.updaterow(); } // insert one new row updrs.movetoinsertrow(); updrs.updateint(1, 5); updrs.updatestring("firstname", "Chritoph"); updrs.updatestring("lastname", "Gruber"); updrs.updateint("born", 1976); updrs.insertrow(); // delete first row updrs.absolute(1); updrs.deleterow(); Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 34
35 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 35
36 Typen Standard-Type-Mapping zwischen SQL und JAVA SQL Type CHAR, VARCHAR, LONGVARCHAR NUMERIC, DECIMAL BIT TINYINT SMALLINT INTEGER BIGINT REAL FLOAT, DOUBLE BINARY, VARBINARY, LONGVARBINARY DATE TIME TIMESTAMP Java Type String java.math.bigdecimal boolean byte short int long float double byte[] java.sql.date java.sql.time java.sql.timestamp Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 36
37 Java Typ JDBC Typ (PreparedStatement) JSR 221, JDBC Specification 4, November 7, 2006, Page 198 Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 37
38 JDBC Typ Java Typ (ResultSet) JSR 221, JDBC Specification 4, November 7, 2006, Page 199 Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 38
39 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 39
40 Metadaten (1/2) Zugriff auf Metadaten über Datenbank über Connection-Objekt DatabaseMetaData getmetadata() throws SQLException DatabaseMetaData erlaubt Zugriff auf Informationen über Datenbanken public interface DatabaseMetaData extends Wrapper { String getdatabaseproductname() throws SQLException; boolean supportstransactions() throws SQLException; ResultSet getprocedures(string catalog, String schemapattern, String procedurenamepattern) throws SQLException; ResultSet gettables(string catalog, String schemapattern, String tablenamepattern, String types[]) throws SQLException; ResultSet getschemas() throws SQLException; ResultSet getcatalogs() throws SQLException; ResultSet getcolumns(string catalog, String schemapattern, String tablenamepattern, String columnnamepattern) throws SQLException; ResultSet getprimarykeys(string catalog, String schema, String table) throws SQLException; } Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 40
41 Metadaten (2/2) Zugriff über Metadaten über ResultSet ResultSetMetaData getmetadata() throws SQLException Zugriff auf Spalteninformation String getcolumnname(int column) int getcolumntype(int column) String getcolumntypename(int column) String gettablename(int column)... Nr Name Max Kurt... Title Mag. DI Age SELECT Nr, Name, Age FORM users; getcolumncount() => 3 getcolumnname(1) => "Nr" getcolumntype(3) => 4 getcolumntypename(3) => "int" gettablename(2) => "users" Nr Name Age Max 25 Kurt Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 41
42 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 42
43 Transaktionen Connection unterstützt Transaktionen Auto Commit: Bei AutoCommit ist jede Anweisung ist eine abgeschlossene Transaktion Kann mit setautocommit bei Connection ausgeschalten werden <Connection>.setAutoCommit(boolean autocommit) Abfragen: boolean <Connection>.getAutoCommit() Abschliessen einer Transaktion: <Connection>.commit() Rücksetzen im Fehlerfall (z.b.: SQLException): <Connection>.rollback() Connection conn;... try { conn.setautocommit(false); Statement stat = conn.createstatement(); stat.executeupdate("insert..."); stat.executeupdate("insert..."); stat.executeupdate("update..."); conn.commit(); } catch (SQLException e) { conn.rollback(); } Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 43
44 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 44
45 Zusammenfassung Datenbankunabhängigkeit Zwischenschicht Treiberschnittstelle (mind. SQL 92) - 4 Treiberarten: JDBC -> ODBC Teilweise Java Nur Java zu einer Middleware Nur Java zur Datenbank Einfachere Programmentwicklung Beliebige SQL-Kommandos absetzbar Optimierung / Datenbankabhängigkeit Arten von Statements java.sql.statement - Statisch oder vom Benutzer frei wählbar (Achtung: SQL injection) java.sql.preparedstatement - Vorbereitete Statements (Sicher gegen SQL injection, schnell) java.sql.callablestatement - Ausführen von SQL stored procedures Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 45
46 Weiteres DataSource als Ersatz für DriverManager (bereits bei JDBC 3.0) erlaubt Auffinden von Datenquellen über JNDI ermöglicht Connection-Pooling ermöglicht verteilte Transaktionen Neuerungen in JDBC 4.0 (Java 6.0) Spezifiziert in JSR-221 Automatisches Laden des Treibers beim Verbindungsaufbau SQL:2003 Unterstützung großer Objekte (CLOB, BLOB) Mehr Datentypen (SQLXML) Neue Exceptions - SQLTransientException - SQLRecoverableException - SQLNonTransientException - Java Datebase Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 46
47 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 47
48 Arbeiten mit Derby Umgebungsvariablen JAVA_HOME= Pfad zur Java-Installation CLASSPATH + C:\Programme\Sun\JavaDB\lib\derby.jar + C:\Programme\Sun\JavaDB\lib\derbytools.jar PATH + C:\Programme\Sun\JavaDB\frameworks\embedded\bin Systeminformationen java org.apache.derby.tools.sysinfo Verzeichnis der Derby- Installation Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 48
49 Arbeiten mit Derby Kommandozeilenwerkzeug java org.apache.derby.tools.ij Verbinden zu, und erzeugen einer Datenbank Erzeugen einer Tabelle Beschreibung einer Tabelle Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 49
50 Arbeiten mit Derby Abfragen von Datensätzen Aktualisieren eines Datensatzes Löschen einer Tabelle Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 50
51 Derby Eclipse Plug-in Derby Plug-in für Eclipse Installation wie jedes andere Plug-in (ins plugin-verzeichnis kopieren) Hinzfügen von Derby ins aktuelle Projekt Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 51
Java Database Connectivity-API (JDBC)
Java Database Connectivity-API (JDBC) Motivation Design Grundlagen Typen Metadaten Transaktionen Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 1 Motivation Problem: Zugriff auf ein DBMS ist Herstellerabhängig
Java Database Connectivity-API (JDBC)
Java Database Connectivity-API (JDBC) Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 1 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen
Java Database Connectivity-API (JDBC)
Java Database Connectivity-API (JDBC) Motivation Design Grundlagen Typen Metadaten Transaktionen Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 1 Motivation Problem: Zugriff auf ein DBMS ist herstellerabhängig
Java Database Connectivity-API (JDBC)
Java Database Connectivity-API (JDBC) Motivation Design Grundlagen Typen Metadaten Transaktionen Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 1 Motivation Problem: Zugriff auf ein DBMS ist Herstellerabhängig
PRAKTIKUM SOFTWAREENTWICKLUNG 2
PRAKTIKUM SOFTWAREENTWICKLUNG 2 JDBC SYSTEM SOFTWARE 1 JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten mit ResultSet Typen Metadaten Transaktionen Zusammenfassung Datenbanksystem Derby
Java Database Connectivity-API (JDBC)
Java Database Connectivity-API (JDBC) Motivation Design Grundlagen Typen Metadaten Transaktionen Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 1 Motivation Problem: Zugriff auf ein DBMS ist Herstellerabhängig
JDBC- JOHANNES KEPLER UNIVERSITY LINZ Research and teaching network. M. Löberbauer, T. Kotzmann, H. Prähofer
JDBC- Java Database Connectivity JOHANNES KEPLER UNIVERSITY LINZ Research and teaching network Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer JDBC Einführung Verbindungsaufbau Datenbankanweisungen
JDBC. JOHANNES KEPLER UNIVERSITY LINZ Research and teaching network. Institut für Systemsoftware, Johannes Kepler Universität Linz
JDBC JOHANNES KEPLER UNIVERSITY LINZ Research and teaching network Pratikum SWE 2 Institut für Systemsoftware, Johannes Kepler Universität Linz JDBC Einführung Verbindungsaufbau Datenbankanweisungen Arbeiten
Java Database Connectivity API / JDBC
Java Database Connectivity API / JDBC Motivation Design Treiber Grundlagen Metadaten Transaktionen Exceptions Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 1 Motivation Problem: Zugriff auf DBMS
Java Database Connectivity API / JDBC
Java Database Connectivity API / JDBC Motivation Design Treiber Grundlagen Metadaten Transaktionen Exceptions Praktikum aus Softwareentwicklung 2 Markus Löberbauer 1 Motivation Problem: Zugriff auf DBMS
Praktikum aus Softwareentwicklung 2, Stunde 7
Praktikum aus Softwareentwicklung 2, Stunde 7 Lehrziele/Inhalt 1. Datenbanken Datenbanken Datenbanken werden in Java über JDBC (ist ein Eigenname, wird aber oft als Abkürzung von Java Database Connectivity
Client/Server-Programmierung
Client/Server-Programmierung WS 2017/2018 Betriebssysteme / verteilte Systeme rolanda.dwismuellera@duni-siegena.de Tel.: 0271/740-4050, Büro: H-B 8404 Stand: 14. September 2017 Betriebssysteme / verteilte
Ho Ngoc Duc IFIS - Universität zu Lübeck
Ho Ngoc Duc IFIS - Universität zu Lübeck 16.04.2003 1 Standard für relationale DB: SQL Vor JDBC: Open Database Connectivity (ODBC), uniforme Schnittstelle für Zugriff JDBC: Programmierschnittstelle (Java-API)
Einführung in JDBC. IFIS Universität zu Lübeck 18.04.2007
Einführung in JDBC IFIS Universität zu Lübeck 18.04.2007 1 Was ist JDBC Standard für relationale DB: SQL Vor JDBC: Open Database Connectivity (ODBC), uniforme Schnittstelle für Zugriff JDBC: Programmierschnittstelle
Datenbanksysteme. Programmieren von Datenbankzugriffen mit JDBC. Burkhardt Renz. Fachbereich MNI Technische Hochschule Mittelhessen
Datenbanksysteme Programmieren von Datenbankzugriffen mit JDBC Burkhardt Renz Fachbereich MNI Technische Hochschule Mittelhessen Sommersemester 2018 Übersicht Architektur von JDBC Ziele von JDBC Grundstruktur
Kapitel 10. JDBC und SQLJ. Prof. Dr. Wolfgang Weber Vorlesung Datenbanken 1
Kapitel 10 JDBC und SQLJ 1 JDBC und SQLJ Bisher: Einbettung von SQL (statisch bzw. dynamisch) in C, C++, COBOL, ADA (embedded SQL) bzw. prozedurale Erweiterungen für SQL in Oracle (PL/SQL) Was ist mit
Client/Server-Programmierung
Client/Server-Programmierung WS 2014/2015 Betriebssysteme / verteilte Systeme rolanda.dwismuellera@duni-siegena.de Tel.: 0271/740-4050, Büro: H-B 8404 Stand: 20. November 2015 Betriebssysteme / verteilte
Datenbanken SQL JDBC. Programmieren II. Dr. Klaus Höppner. Hochschule Darmstadt Sommersemester / 21
Programmieren II Dr. Klaus Höppner Hochschule Darmstadt Sommersemester 2010 1 / 21 Datenbanken SQL JDBC 2 / 21 Relationale Datenbanken Ein Datenbanksystem ist ein System zur Speicherung von (großen) Datenmengen:
Datenbanken SQL-Grundlagen JDBC SQL-Constraints. Programmieren II. Martin Schultheiß. Hochschule Darmstadt Sommersemester 2011
Programmieren II Martin Schultheiß Hochschule Darmstadt Sommersemester 2011 1 Datenbanken 2 SQL-Grundlagen 3 JDBC 4 SQL-Constraints Relationale Datenbanken Ein Datenbanksystem ist ein System zur Speicherung
Universität Augsburg, Institut für Informatik WS 2006/2007 Dr. W.-T. Balke 11. Dez M. Endres, A. Huhn, T. Preisinger Lösungsblatt 7
Universität Augsburg, Institut für Informatik WS 2006/2007 Dr. W.-T. Balke 11. Dez. 2006 M. Endres, A. Huhn, T. Preisinger Lösungsblatt 7 Aufgabe 2 + 3: Datenbanksysteme I import java.sql.*; import oracle.jdbc.driver.*;
seit Java 1.1 Bestandteil der API: packages java.sql, javax.sql
JDBC inoffizielle Abkürzung für: Java Database Connectivity seit Java 1.1 Bestandteil der API: packages java.sql, javax.sql ist eine Menge von Klassen und Methoden, um aus Java-Programmen relationale Datenbanken
Willkommen. Datenbanken und Anbindung
Willkommen Datenbanken und Anbindung Welche stehen zur Wahl? MySQL Sehr weit verbreitetes DBS (YT, FB, Twitter) Open-Source und Enterprise-Version Libs in C/C++ und Java verfügbar Grundsätzlich ist ein
Java: MySQL-Anbindung mit JDBC.
Java: MySQL-Anbindung mit JDBC Vorarbeiten Wir brauchen: - MySQL-Server - JDBC-Treiber - (Import java.sql.*) Vorarbeiten MySQL-Server in unserem Falle: WAMP (= Apache) (runterladen, installieren, starten)
Programmieren II. Beispiele für RDBMS. Relationale Datenbanken. Datenbanken SQL. Dr. Klaus Höppner JDBC. Hochschule Darmstadt SS 2008
Programmieren II Datenbanken Dr. Klaus Höppner SQL Hochschule Darmstadt SS 2008 JDBC 1 / 20 2 / 20 Relationale Datenbanken Beispiele für RDBMS Ein Datenbanksystem ist ein System zur Speicherung von (großen)
Java Database Connectivity (JDBC) 14.07.2009 Walther Rathenau Gewerbeschule 1
Java Database Connectivity (JDBC) 14.07.2009 Walther Rathenau Gewerbeschule 1 Was ist JDBC? Hauptsächlich eine Sammlung von Java Klassen und Schnittstellen für eine einfache Verbindung von Java Programmen
Datenbankanwendungen (JDBC)
Datenbankanwendungen (JDBC) Hierarchie: Connection Transaction Statement Connection Aufbau (klassisch): Registrierung des JDBC Driver beim DriverManager: Class.forName(JDBC Driver); Eigentlicher Verbindungsaufbau
Java Database Connectivity. Gracin Denis, IB 4 C
Java Database Connectivity Gracin Denis, IB 4 C Agenda 1. JDBC-Architektur 2. Treiber der JDBC 2.1 Typ-1 Treiber 2.2 Typ-2 Treiber 2.3 Typ-3 Treiber 2.4 Typ-4 Treiber 3. Verbindungsablauf 4. Connection
JDBC. Java DataBase Connectivity
JDBC Java DataBase Connectivity JDBC-Schichten JDBC besteht aus 2 Teilen, 1. aus Datenbanktreibern, die den Anschluß von Java-Anwendungen an Datenbanksysteme wie Sybase, DB/2, Oracle, MS ACCESS oder Mini
Grundlagen von Datenbanken SS 2010 Kapitel 8: Datenbank-Einbettung in Programmiersprachen Prof. Dr. Stefan Böttcher Universität Paderborn
Grundlagen von Datenbanken SS 2010 Kapitel 8: Datenbank-Einbettung in Programmiersprachen Prof. Dr. Stefan Böttcher Universität Paderborn Grundlagen von Datenbanken - SS 2010 - Prof. Dr. Stefan Böttcher
Datenbankentwurf & Datenbankzugriff mit JDBC. Georg Köster Sven Wagner-Boysen
Datenbankentwurf & Datenbankzugriff mit JDBC Georg Köster Sven Wagner-Boysen 6. November 2007 Gliederung 2 Datenbankentwurf für ProminentPeople.info ER-Modell Relationaler Entwurf Normalisierung Datenbankzugriff
Datenbanksysteme. Programmieren von Datenbankzugriffen mit JDBC. Burkhardt Renz. Fachbereich MNI Technische Hochschule Mittelhessen
Programmieren von Datenbankzugriffen mit JDBC Fachbereich MNI Technische Hochschule Mittelhessen Sommersemester 2015 Überblick über das Package java.sql Übersicht Architektur von JDBC Grundstruktur eines
Ziel: Verständnis für Konzepte von JDBC aufbauen
11. JDBC Grundsätzliche Nutzung von JDBC Verbindungsaufbau Anfragen Analyse des erhaltenen Ergebnisses Veränderungen des Ergebnisses Ziel: Verständnis für Konzepte von JDBC aufbauen 253 Überblick: Datenbankanfragen
Vorlesung Informatik II
Vorlesung Informatik II Universität Augsburg Sommersemester 2011 Prof. Dr. Robert Lorenz Lehrprofessur für Informatik 10. Java: Datenhaltung mit Datenbanken 1 Datenbank-Programme Derby (Hersteller: Apache
Universität Augsburg, Institut für Informatik WS 2014/2015 Prof. Dr. W. Kießling 05. Dez F. Wenzel, L. Rudenko Lösungsblatt 7
Universität Augsburg, Institut für Informatik WS 2014/2015 Prof. Dr. W. Kießling 05. Dez. 2014 F. Wenzel, L. Rudenko Lösungsblatt 7 Aufgabe 1: JDBC 2.0 und Scrollable Result Sets Datenbanksysteme I Lösungen
Datenbankschnittstellen erlauben Zugriff auf Datenbank aus einer externen Anwendung
Rückblick Datenbankschnittstellen erlauben Zugriff auf Datenbank aus einer externen Anwendung Portabilität als wichtige Anforderung, d.h. RDBMS oder Programmiersprache soll leicht austauschbar sein Call-Level
Kapitel DB:VI (Fortsetzung)
Kapitel DB:VI (Fortsetzung) VI. Die relationale Datenbanksprache SQL Einführung SQL als Datenanfragesprache SQL als Datendefinitionssprache SQL als Datenmanipulationssprache Sichten SQL vom Programm aus
Datenbanksysteme I. Aufgabe 1: Erstellen einer Multimedia-Datenbank. Grundlage sind wiederum bereits implementierte Methoden aus Übungsblatt 6:
Universität Augsburg, Institut für Informatik Wintersemester 2010/2011 Prof. Dr. W. Kießling 17. Dez. 2010 Dr. A. Huhn, F. Wenzel, M. Endres Lösungsblatt 7 Aufgabe 1: Erstellen einer Multimedia-Datenbank
Programmieren II. Relationale Datenbanken. Vorlesung 07. Handout S. 1. Martin Schultheiß. Hochschule Darmstadt Sommersemester 2011.
Programmieren II Martin Schultheiß Hochschule Darmstadt Sommersemester 2011 1 / 26 Datenbanken SQL-Grundlagen JDBC SQL-Constraints 2 / 26 Relationale Datenbanken Ein Datenbanksystem ist ein System zur
Universität Augsburg, Institut für Informatik WS 2009/2010 Prof. Dr. W. Kießling 18. Dez Dr. A. Huhn, F. Wenzel, M. Endres Lösungsblatt 8
Universität Augsburg, Institut für Informatik WS 2009/2010 Prof. Dr. W. Kießling 18. Dez. 2009 Dr. A. Huhn, F. Wenzel, M. Endres Lösungsblatt 8 Aufgabe 1: JDBC 2.0 und Scrollable Result Sets Datenbanksysteme
Java und Datenbanksysteme Datenbankanbindung mit JDBC
Java und Datenbanksysteme Datenbankanbindung mit JDBC 30.05.2001 Stefan Niederhauser sn@atelier-w.ch 1-Einführung Datenbanksysteme Java und Datenbanken: JDBC Geschichte der JDBC-Versionen Vergleich von
Datenbanksysteme 2011
Datenbanksysteme 2011 noch Kapitel 10: Datenbankapplikationen Oliver Vornberger Institut für Informatik Universität Osnabrück Datenbankapplikationen MS Visio MS Access Embedded SQL im C-Programm JDBC /
Tag 5 Inhaltsverzeichnis
Tag 5 Inhaltsverzeichnis ODBC / JDBC: Ziel und Prinzip JDBC Überblick Erstes Beispiel Queries (Execute- und UpdateQuery) Der Typ "ResultSet" Diverses Metadata PreparedStatement Transaktionen und Batches
Oracle & Java HOW TO
Oracle & Java HOW TO Helge Janicke, Niels-Peter de Witt, Karsten Wolke 21. Januar 2002 Inhaltsverzeichnis 1 Java-Anbindung an Oracle-DB 2 2 Benötigte Programme und Daten 2 3 Einbinden der Klassen 2 4 Aufbau
JDBC. Es kann z.b. eine ODBC-Treiberverbindung eingerichtet werden, damit das JAVA-Programm auf eine ACCESS-DB zugreifen kann.
JDBC in 5 Schritten JDBC (Java Database Connectivity) ist eine Sammlung von Klassen und Schnittstellen, mit deren Hilfe man Verbindungen zwischen Javaprogrammen und Datenbanken herstellen kann. 1 Einrichten
11. JDBC. Grundsätzliche Nutzung von JDBC Verbindungsaufbau Anfragen Analyse des erhaltenen Ergebnisses Veränderungen des Ergebnisses
11. JDBC Grundsätzliche Nutzung von JDBC Verbindungsaufbau Anfragen Analyse des erhaltenen Ergebnisses Veränderungen des Ergebnisses Ziel: Verständnis für Konzepte von JDBC aufbauen 270 Überblick: Datenbankanfragen
Ausgewählte Implementierungsprobleme
Ausgewählte Implementierungsprobleme Rebecca Tiarks 22. Januar 2009 1 / 50 Inhaltsverzeichnis 1 2 / 50 Datenbanken Sammeln, Zugreifen und Verwalten von Daten in der Computerwelt geschieht das mit Datenbanken
Klausur Datenbanken II
Klausur Datenbanken II 8.3.2001 Name Vorname Semester Matrikelnr Aufgabe Punkte maximal 1 8 2 8 3 3 4 3 5 4 6 6 7 6 8 6 9 [Zusatz] [4] Summe 44 Punkte erreicht Bitte geben Sie die Lösungen möglichst direkt
Webbasierte Informationssysteme
SS 2004 Prof. Dr. Stefan Böttcher Universität Paderborn - SS 2004 - Prof. Dr. Stefan Böttcher Folie 1 Was ist eine relationale Datenbank? Menge von Relationen (=Tabellen) und Constraints (=Integritätsbedingungen)
1a) SQL Stored Procedure via IDs
1a) SQL Stored Procedure via IDs Erstellen Sie analog zu Aufgabe 2d) des ersten Übungsblatts eine SQL Stored Procedure, welche den Freundschaftsgrad zweier Benutzer eines sozialen Netzwerks aktualisiert.dazu
Java und Datenbanken
Java und Datenbanken Benutzerschnittstelle DB-Client Client Benutzerschnittstelle CORBA, HTTP,... DB-Client Anwendungslogik DB-Schnittstelle JDBC, SQLJ Anwendungslogik DB-Schnittstelle Anwendungs- Server
Musterlösung Übungsblatt 11
Julia Wolters Abgabe: 06.07.2009 Aufgabe 41 1 Aufgabe 41 2 3 CREATE TABLE auftraege ( 4 anfang TIMESTAMP NOT NULL, 5 ende TIMESTAMP, 6 kunde VARCHAR, 7 beschreibung VARCHAR, 8 PRIMARY KEY ( anfang, kunde,
Vorlesung Datenbanksysteme vom JDBC. Einführung JDBC-Verbindungen Schreibzugriff mit SQL SELECT Anweisungen prepared/callable Statements
Vorlesung Datenbanksysteme vom 17.10.2007 JDBC Einführung JDBC-Verbindungen Schreibzugriff mit SQL SELECT Anweisungen prepared/callable Statements Einführung DB-Anbindung an Programmiersprachen Embedded
Vorlesung Datenbanksysteme vom JDBC. Einführung JDBC-Verbindungen Schreibzugriff mit SQL SELECT Anweisungen prepared/callable Statements
Vorlesung Datenbanksysteme vom 15.10.2008 JDBC Einführung JDBC-Verbindungen Schreibzugriff mit SQL SELECT Anweisungen prepared/callable Statements Einführung DB-Anbindung an Programmiersprachen Embedded
Android Programmierung. Studiengang MI
Android Programmierung mit Java Studiengang MI Dipl.-Inf., Dipl.-Ing. (FH) Michael Wilhelm Hochschule Harz FB Automatisierung und Informatik mwilhelm@hs-harz.de http://mwilhelm.hs-harz.de Raum 2.202 Tel.
Tag 5 Inhaltsverzeichnis
Tag 5 Inhaltsverzeichnis ODBC / JDBC: Ziel und Prinzip JDBC Überblick Erstes Beispiel Queries (Execute- und UpdateQuery) Der Typ "ResultSet" Diverses Metadata PreparedStatement Transaktionen und Batches
Universität Augsburg, Institut für Informatik WS 2011/2012 Prof. Dr. W. Kießling 09. Dez Dr. M. Endres, Dr. S. Mandl, F. Wenzel Lösungsblatt 6
Universität Augsburg, Institut für Informatik WS 2011/2012 Prof. Dr. W. Kießling 09. Dez. 2011 Dr. M. Endres, Dr. S. Mandl, F. Wenzel Lösungsblatt 6 Datenbanksysteme I Aufgabe 1: Deklarative Änderungsoperationen
11 Anwendungsprogrammierung
11 11 11.1 Programmiersprachenanbindung 11.2 11.3 183 11 Programmiersprachenanbindung Programmiersprachenanbindung Kopplungsarten: prozedurale oder CALL-Schnittstellen (call level interface) Beispiele:
Datenbank und Informationssysteme
Datenbank und Informationssysteme Inhaltsverzeichnis 1 Programmierung von Datenbankzugriffen 3 1.1 Architektur des SQL/CLI am Beispiel JDBC................... 4 1.2 Anfragen und Ergebnismengen in JDBC......................
Kapitel DB:VI (Fortsetzung)
Kapitel DB:VI (Fortsetzung) VI. Die relationale Datenbanksprache SQL Einführung SQL als Datenanfragesprache SQL als Datendefinitionssprache SQL als Datenmanipulationssprache Sichten SQL vom Programm aus
JDBC. VU Datenbanksysteme. Wolfgang Fischl
JDBC VU Datenbanksysteme Wolfgang Fischl Arbeitsbereich Datenbanken und Artificial Intelligence Institut für Informationssysteme Technische Universität Wien Wintersemester 2015/16 Gliederung Einführung
DB-Programmierung. Lehr- und Forschungseinheit Datenbanken und Informationssysteme 1. Ziele. DB2 Zugriff mit Java selbst programmieren
DB-Programmierung Lehr- und Forschungseinheit Datenbanken und Informationssysteme 1 Ziele static SQL verstehen Build-Prozess / Art des Datenzugriffs Host-Variablen Vor- / Nachteile dynamic SQL verstehen
Anwendungsentwicklung für relationale Datenbanken setzt voraus, dass prozedurale Abläufe programmiert werden können!
Datenbanken: Standard CLI und JDBC Anwendungsentwicklung für relationale Datenbanken setzt voraus, dass prozedurale Abläufe programmiert werden können! (Endanwendern ist nicht zuzumuten, SQL zu lernen
JDBC. VL Datenbanksysteme. Ingo Feinerer
JDBC VL Datenbanksysteme Ingo Feinerer Arbeitsbereich Datenbanken und Artificial Intelligence Institut für Informationssysteme Technische Universität Wien Gliederung Einführung DB-Anbindung an Programmiersprachen
Hauptschritte einer JDBC-App
JDBC Java DataBase Connectivity Sammlung von Klassen und Interfaces zur Arbeit mit Datenbanken auf Basis von SQL Package java.sql Datenbankmanagementsystem und eine oder mehrere Datenbanken Jdbc Driver,
Hauptschritte einer JDBC-App
JDBC Java DataBase Connectivity Sammlung von Klassen und Interfaces zur Arbeit mit Datenbanken auf Basis von SQL Package java.sql Datenbankmanagementsystem und eine oder mehrere Datenbanken Jdbc Driver,
Webbasierte Informationssysteme
SS 2004 Prof. Dr. Stefan Böttcher Universität Paderborn - SS 2004 - Prof. Dr. Stefan Böttcher Folie 1 Was ist eine relationale Datenbank? Menge von Relationen (=Tabellen) und Constraints (=Integritätsbedingungen)
Das diesem Dokument zugrundeliegende Vorhaben wurde mit Mitteln des Bundesministeriums für Bildung und Forschung unter dem Förderkennzeichen
Das diesem Dokument zugrundeliegende Vorhaben wurde mit Mitteln des Bundesministeriums für Bildung und Forschung unter dem Förderkennzeichen 16OH21005 gefördert. Die Verantwortung für den Inhalt dieser
Datenbankzugriff mit JDBC
Java: Kapitel 8 Datenbankzugriff mit JDBC Programmentwicklung WS 2008/2009 Holger Röder holger.roeder@informatik.uni-stuttgart.de Überblick über Kapitel 8 Einführung in SQL und JDBC Verbindung zur Datenbank
Kapitel 11: Anwendungsentwicklung
Ludwig Maximilians Universität München Institut für Informatik Lehr- und Forschungseinheit für Datenbanksysteme Skript zur Vorlesung Wintersemester 2015/2016 Kapitel 11: Anwendungsentwicklung Vorlesung:
Datenbankzugriff mit JDBC
Datenbankzugriff mit Praktikum aus Softwareentwicklung 2 Abteilung für Bioinformatik, JKU Linz - 1 Datenbankzugriff mit Grundlagen, DriverManager, Connection, HSQLDB Installation und Anwendung Abteilung
Kapitel 11: Anwendungsentwicklung
Skript zur Vorlesung Wintersemester 2005/2006 Kapitel 11: Anwendungsentwicklung Vorlesung: Dr. Matthias Schubert Übungen: Elke Achtert, Arthur Zimek Skript 2004 Christian Böhm http://www.dbs.informatik.uni-muenchen.de/lehre/dbs
Wie kommen die Befehle zum DBMS
Wie kommen die Befehle zum DBMS Dr. Karsten Tolle Datenbanken und Informationssysteme Wie kommen die Befehle zum DBMS Bisher gesehen: SQL direkt zum DBMS Workbench Kommandozeile IBM Query Tool Weitere?
Datenbanken 1 für Mediennformatiker WS 06. 4. ODBC, JDBC und SQLJ: Datenbank-Anbindung an Anwendungsprogramme
Datenbanken 1 für Mediennformatiker WS 06 4. ODBC, JDBC und SQLJ: Datenbank-Anbindung an Anwendungsprogramme Der letzte Schritt Diese grafische Oberfläche mit der Ebay-Datenbank verbinden... Anwendungen
Datenbanksysteme I Übung: JDBC. Jana Bauckmann
Datenbanksysteme I Übung: JDBC Jana Bauckmann Wo reicht SQL alleine nicht? 2 Web-Anwendungen Daten übersichtlich und schön präsentieren Komplizierte Fragestellungen Sind sich 2 Tupel ähnlich? Duplikaterkennung
Datenbanksysteme I. Aufgabe 1: JDBC Fehlerbehandlung und Meta Data. Lösungsvorschlag:
Universität Augsburg, Institut für Informatik WS 2011/2012 Prof. Dr. W. Kießling 16. Dez. 2011 Dr. M. Endres, Dr. S. Mandl, F. Wenzel Lösungsblatt 7 Datenbanksysteme I Aufgabe 1: JDBC Fehlerbehandlung
Kurzübersicht JDBC. Marc Monecke. monecke@informatik.uni-siegen.de. 15. Januar 2003
Kurzübersicht JDBC Marc Monecke monecke@informatik.uni-siegen.de 15. Januar 2003 Zusammenfassung Über JDBC-Schnittstellen können Anwendungsprogramme auf Datenbanken zugreifen, ohne daß dabei hersteller-
3. Datenbankzugriff (JDBC) Grundlagen der Programmierung II (Java)
3. Datenbankzugriff (JDBC) Grundlagen der Programmierung II (Java) Prof. Dr. Bernhard Humm Hochschule Darmstadt University of Applied Sciences Sommersemester 2006 Übersicht Grundlagen der Programmierung
vs. Fehler zur Übersetzungszeit
Client-Server-Architektur, Anbindung von Programmiersprachen, Call-Level-Schnittstellen: /, JDBC, :, J, gespeicherte Prozeduren, prozedurale Erweiterungen: /PSM, PL/. IPD, Forschungsbereich Systeme der
MySQL, phpmyadmin & SQL. Kurzübersicht
MySQL, phpmyadmin & SQL Kurzübersicht Referenzen MySQL Documentation: http://dev.mysql.com/doc PHP 5 / MySQL5. Studienausgabe. Praxisbuch und Referenz (Kannengießer & Kannengießer) 2 Datenbank anlegen
Ausarbeitung des Referats JDBC
. Markus Zywitza Markus Zywitza Matr.-Nr. 832576 Email: i753@informatik.fh-wiesbaden.de mzywitza@t-online.de markus.zywitza@gmx.de Ausarbeitung des Referats JDBC.......... Datenbank-Anbindung unter Java
Übersicht. Relationale Datenbanken SQL - Structured Query Language JDBC - Java Datenbank Schnittstelle Beispielanwendung. R. Kopetzky 7.
Informatik Verbund Stuttgart der Universität Stuttgart Tutorium Java Anbindung von Datenbanken mit JDBC (kopetzky@ike.uni-stuttgart.de) Übersicht Relationale Datenbanken SQL - Structured Query Language
Modifikation der Datenbank
Modifikation der Datenbank Löschen Einfügen Änderungen Änderungen von Sichten 71 Löschen Wir haben bereits gesehen, dass wir den gesamten Inhalt einer Tabelle r löschen können durch das Kommando: delete
PROGRAMMIERPROJEKT 2016 VERWENDETE TECHNOLOGIEN
PROGRAMMIERPROJEKT 2016 VERWENDETE TECHNOLOGIEN Mathias Weber und Annette Bieniusa ÜBERBLICK Spark SQL SQL in Java SPARK WAS IST DAS? Framework zur Erstellung von Web-Anwendungen in Java Einfach zu verwenden
Beispiel: DB-Mock (1/7)
Beispiel: DB-Mock (1/7) Aufgabe: DB, auf die vereinfachend nur lesend zugeriffen wird mocken warum: benötigte keine DB-Lizenz, garantiert gleiche Werte ohne aufwändiges reset, kein Zeitverlust durch Verbindungsaufbau
Universität Augsburg, Institut für Informatik WS 2009/2010 Prof. Dr. W. Kießling 11. Dez Dr. A. Huhn, F. Wenzel, M. Endres Lösungsblatt 7
Universität Augsburg, Institut für Informatik WS 2009/2010 Prof. Dr. W. Kießling 11. Dez. 2009 Dr. A. Huhn, F. Wenzel, M. Endres Lösungsblatt 7 Aufgabe 1: Basisoperationen mit JDBC Datenbanksysteme I a)
Datenbankzugriff mit JDBC
Datenbankzugriff mit JDBC Praktikum aus Java Praktikum SS 2010 Gerald.Ehmayer@borland.com 1 Datenbankzugriff mit JDBC HSQLDB Installation und Anwendung JDBC Grundlagen, DriverManager, Connection, Java
Java Application 1 Java Application 2. JDBC DriverManager. JDBC-ODBC Br idge. ODBC Driver Manager. Dr iver C. Dr iver D.
1 Copyright 1996-1997 by Axel T. Schreiner. All Rights Reserved. 7 Datenbankzugriff Prinzip Dieser Abschnitt beschäftigt sich mit dem Paket java.sql, das eine SQL-Schnittstelle für Java verkapselt. Java-Programme
6. Java Database Connectivity. Prof. Dr.-Ing. Wolfgang Lehner
6. Java Database Connectivity Prof. Dr.-Ing. Wolfgang Lehner > Roadmap intern intern/extern extern SQL UDF SQL SP XQUERY Trigger ext. UDF ext. SP SQLJ Embedded SQL JDBC ODBC OLE.NET Kommunikationslast
Oracle: Abstrakte Datentypen:
Oracle: Abstrakte Datentypen: Oracle bietet zwei mögliche Arten um abstrakte Datentypen zu implementieren: Varying Array Nested Table Varying Array (kunde) kdnr kdname gekaufteart 1 Mustermann 1 4 5 8