Diplomarbeit. Evaluierung einer Datenbankmigration am Beispiel von Oracle Database und Microsoft SQL Server

Größe: px
Ab Seite anzeigen:

Download "Diplomarbeit. Evaluierung einer Datenbankmigration am Beispiel von Oracle Database und Microsoft SQL Server"

Transkript

1 Fachhochschule Köln University of Applied Sciences Cologne Campus Gummersbach Fakultät für Informatik und Ingenieurwissenschaften Diplomarbeit zur Erlangung des Diplomgrades Diplom-Informatiker (FH) in der Fachrichtung Informatik Evaluierung einer Datenbankmigration am Beispiel von Oracle Database und Microsoft SQL Server Erstprüfer: Prof. Dr. Heide Faeskorn-Woyke Zweitprüfer: Dipl. Ing. Johannes Ahrends vorgelegt am: von: Erdal Türkeri Gelpestr. 42a Gummersbach Matrikelnummer:

2 Inhaltsverzeichnis 2 Inhaltsverzeichnis ABBILDUNGSVERZEICHNIS...3 TABELLENVERZEICHNIS EINLEITUNG Motivation und Problemstellung Zielsetzung und Vorgehensweise Danksagung ARCHITEKTUR-VERGLEICH Physische Datenbankarchitektur Logische Datenbankarchitektur Logische Speichereinheiten Instanzen DATENBANKOBJEKTE Datentypzuordnungen Unterschiede zwischen ANSI-SQL und ORACLE-SQL Namenskollisionen Maximal zulässige Größen der SQL Server Datenbankmodul- Objekte SPERRKONZEPTE LOCKING LOCKING in SQL Server LOCKING in Oracle Lesekonsistenz Lesekonsistenz in SQL Server Lesekonsistenz in Oracle Isolationsstufen Isolationsstufen in SQL Server Isolationsstufen in Oracle MIGRATION VON ORACLE ZU SQL SERVER Migration mit dem Microsoft SQL Server Migration Assistant (SSMA for Oracle) Assessment Report Probleme Konvertierungsweise Ergebnis MIGRATION VON SQL SERVER ZU ORACLE Migration mit dem Oracle SQL Developer Probleme Ergebnis SCHLUSSBETRACHTUNG...69 LITERATURVERZEICHNIS...71 ANHANG A...74 ANHANG B...78 ERKLÄRUNG...79

3 Abbildungsverzeichnis 3 Abbildungsverzeichnis Abbildung 1: Snapshot TDM mit ER-Modell Oracle-DEMO...38 Abbildung 2: Snapshot des Microsoft Migration Assistant for Oracle...39 Abbildung 3: Snapshot eines Assessment Reports...41 Abbildung 4: Tabelle Personen in Oracle...46 Abbildung 5: Tabelle Personen in SQL Server...46 Abbildung 6: Snapshot TDM mit ER-Modell SQL Server-DEMO...52 Abbildung 7: Snapshot TDM mit ER-Modell SQL Server-WAWI...55 Abbildung 8: Snapshot des Oracle SQL Developers...57 Abbildung 9: Oracle Migration Workbench Architektur...58 Abbildung 10: Snapshot des SQL Developer Script Output-Fensters...58 Abbildung 11: Snapshot Toad for Oracle...59 Abbildung 12: Snapshot TDM mit ER-Modell Oracle-WAWI...68

4 Tabellenverzeichnis 4 Tabellenverzeichnis Tabelle 1: Schema-Objekte von Oracle und SQL-Server...11 Tabelle 2: Datentypzuordnungen von Oracle zu SQL Server...13 Tabelle 3: Datentypzuordnungen von SQL Server zu Oracle...14 Tabelle 4: Datums- und Zeitangaben in SQL Server...15 Tabelle 5: Datums- und Zeitangaben in Oracle...15 Tabelle 6: NULL-Konstrukte in Oracle und SQL Server...17 Tabelle 7: SQL-Syntaxunterschiede...20 Tabelle 8: Syntaxunterschiede von PL/SQL und T-SQL...21 Tabelle 9: Operatorunterschiede...22 Tabelle 10: Reservierte Schlüsselwörter des SQL Server...23 Tabelle 11: Reservierte ODBC-Schlüsselwörter des SQL Server...24 Tabelle 12: Zukünftige Schlüsselwörter des SQL Server...24 Tabelle 13: Automatische Sperrmodi des SQL Server...27 Tabelle 14: Beabsichtigte Sperren des SQL Server...29 Tabelle 15: Automatische Sperrmodi von Oracle...30 Tabelle 16: Manuelle Sperrmodi von Oracle...31 Tabelle 17: Parallelitätsnebeneffekte in SQL Server...35 Tabelle 18: Parallelitätsnebeneffekte in Oracle...36 Tabelle 19: Konvertierungsstatistik des SSMA...40 Tabelle 20: Konvertierungsweise des SSMA...48 Tabelle 21: Maximale Kapazität für SQL Server

5 1 Einleitung 5 1 Einleitung 1.1 Motivation und Problemstellung Zahlreiche Gründe können Unternehmen dazu veranlassen von einem kommerziellen Datenbankmanagementsystem auf das eines anderen Herstellers zu wechseln. Einer der Gründe sind die Kosten. In den letzten Jahren sind bei den kommerziellen Datenbanken Änderungen zu verzeichnen. Dies betrifft sowohl die generelle Leistungsfähigkeit der verschiedenen Systeme als auch die Verschiedenheit der Kosten innerhalb der einzelnen Systeme, ebenso die Kompatibilität der einzelnen Systeme untereinander. Die finanzielle Realität für die meisten Unternehmen ist, dass zu viel ihres Etats durch ihre vorhandene IT-Infrastruktur verbraucht wird und zu wenig für neue IT-Investitionen vorhanden ist. Dementsprechend ist die Senkung der Kosten für die IT- Infrastruktur für viele leitende IT-Manager oberstes Gebot. Datenbanken sind dabei ein lohnenswertes Ziel für geplante Sparmaßnahmen, da hiermit ein erheblicher Aufwand sowohl im Hinblick auf die IT-Arbeitsleistung als auch im Hinblick auf die Personalkosten verbunden ist. Weitere Gründe einer Datenbankmigration können Anforderungen an den Herstellersupport, die Kompatibilität zu anderen Datenbanken oder andere Gründe sein. Hier soll allerdings nicht die genaue Kostenstruktur untersucht werden, sondern die technischen Aspekte einer Umstellung. Datenbankmigrationen stellen im Hinblick auf die Kosten und die Komplexität eine erhebliche Herausforderung dar. Vorhandene Daten aus einem alten System auf ein neues System eines anderen Herstellers zu übertragen ist sehr aufwendig, weil insbesondere system- bzw. herstellerspezifische Besonderheiten nicht übernommen werden können. 1.2 Zielsetzung und Vorgehensweise Ziel dieser Diplomarbeit ist anhand von Praxisbeispielen Migrationen zwischen den beiden kommerziellen Datenbankmanagementsystemen Oracle Database und Microsoft SQL Server durchzuführen und die Ergebnisse zu untersuchen.

6 1 Einleitung 6 Dabei werden Migrationswerkzeuge beider Hersteller verwendet, die nach Herstellerangaben eine schnelle, einfache und akkurate Migration von fremden Datenbankmanagementsystemen auf das eigene System unterstützen sollen. Es soll untersucht werden, ob mit diesen Migrationswerkzeugen die Schema- und Datenmigration automatisiert werden kann. In dieser Diplomarbeit soll zunächst einmal in Kapitel 2 die physische und die logische Datenbankarchitektur von Oracle Database und Microsoft SQL Server gegenübergestellt werden, wobei auch einige theoretische und begriffliche Grundlagen dargelegt werden. Danach werden in Kapitel 3 Datenbankobjekte der beiden Systeme verglichen, wobei unter anderem Datentypzuordnungen und Syntax-Unterschiede aufgeführt werden. In Kapitel 4 werden die unterschiedlichen Sperrkonzepte der beiden Systeme behandelt. In Kapitel 5 wird anhand eines Praxisbeispiels das Ergebnis einer Migration von Oracle zu SQL Server dargelegt. Anschließend wird in Kapitel 6 wiederum anhand eines Praxisbeispiels das Ergebnis einer Migration von SQL Server zu Oracle dargelegt. Schließlich werden in Kapitel 7 die wichtigsten Ergebnisse dieser Diplomarbeit zusammengefasst. 1.3 Danksagung Ich danke Frau Prof. Dr. Heide Faeskorn-Woyke, durch die ich dieses Diplomarbeitsthema gefunden habe und die mich mit Herrn Ahrends in Kontakt gebracht hat. Herrn Dipl. Ing. Johannes Ahrends danke ich dafür, dass er mir einen Arbeitsplatz bei der Quest Software GmbH zur Verfügung gestellt hat und mir immer mit seinem bemerkenswerten Fachwissen mit Rat und Tat zur Seite stand. Ebenso bedanke ich mich ausdrücklich bei Herrn Dipl. Inf. Patrick Schwanke, der mich sehr geduldig mit seinen beeindruckenden PL/SQL Kenntnissen unterstützt hat und auch Herrn Dipl. Inf. Thomas Klughardt, der stets ein offenes Ohr für meine Fragen hatte. Schließlich möchte ich noch allen anderen Quest Mitarbeitern für ihr herzliches Entgegenkommen und ihre Unterstützung danken.

7 2 Architektur-Vergleich 7 2 Architektur-Vergleich Oracle Database und Microsoft SQL Server sind relationale Datenbankmanagementsysteme. Dabei ist Oracle für fast alle heute verwendeten Plattformen verfügbar wohingegen der SQL Server nur auf Basis von Microsoft Windows Plattformen erhältlich ist. Die Database Engine (Datenbankmodul) des SQL Servers ist der eigentliche Kerndienst, mit dem das Speichern, Verarbeiten und Sichern von Daten realisiert wird. Das Datenbankmodul ist ein Teilbereich des SQL Servers. Daneben gibt es noch viele weitere herstellerabhängige Merkmale, die bei einer Migration beachtet werden müssen. Beispielsweise verläuft die Datenspeicherung, die Datensicherung oder die Transaktionsverwaltung der jeweiligen Systeme grundsätzlich unterschiedlich. Aus diesem Grund sollte zunächst einmal verglichen werden, inwieweit bestimmte Konstruktionen in beiden Systemen vorhanden sind. Daher sollen die unterschiedlichen physischen- und logischen Datenbankarchitekturen nachfolgend kurz erläutert werden. Ferner soll dies auch dazu dienen, einen kleinen Überblick über die unterschiedlichen Nomenklaturen, die in beiden Systemen verwendet werden, zu erlangen. 2.1 Physische Datenbankarchitektur Oracle-Dateiarten In einer Oracle-Datenbank werden die folgenden, unverzichtbaren Dateiarten unterschieden 1 2 : Kontrolldateien: Diese Dateien enthalten Informationen über die physische Datenbankstruktur, die u.a. für Backup- und Recovery-Aktionen sowie für die Konsistenzsicherung notwendig sind. Datendateien: Diese Dateien enthalten alle Benutzer- und Metadaten der Datenbank. 1 Vgl. [Ahrends06] Seite Vgl. [Best05] Kapitel 1, Seite 15

8 2 Architektur-Vergleich 8 Online-Redolog-Dateien: Diese Dateien enthalten sämtliche Transaktions- protokollinformationen, die zum Wiederherstellen der Datenbank benötigt werden. SQL Server-Dateiarten SQL Server verwendet drei Arten von Dateien 3 : Primäre Datendateien: Enthält die Startinformationen für die Datenbank und zeigt auf die anderen Dateien in der Datenbank. Sekundäre Datendateien: Sekundäre Datendateien sind optional, benutzerdefiniert und speichern Benutzerdaten. Protokolldateien: Diese Dateien enthalten sämtliche Transaktionsprotokollinformationen, die zum Wiederherstellen der Datenbank benötigt werden. 2.2 Logische Datenbankarchitektur Logische Speichereinheiten Oracle-Tablespaces Oracle-Datenbanken sind in logische Speichereinheiten (Tablespaces) unterteilt, die auf der physikalischen Ebene durch Datendateien repräsentiert werden 4. Durch die Trennung der logischen Architektur und der physikalischen Speicherung wird der gleiche Aufbau der Datenbank auf unterschiedlichen Plattformen ermöglicht. Tablespaces bestehen aus einer oder mehreren Datendateien. Jede Datendatei kann jeweils nur einem Tablespace angehören. Folgende Tablespaces sollten in einer Oracle 10g-Datenbank nicht fehlen: SYSTEM: Speichert die Tabellen, die die Kernfunktionalität der Datenbank unterstützen, beispielsweise Data Dictionary-Tabellen. (Obligatorisch) SYSAUX: Speichert zahlreiche Datenbankkomponenten wie beispielsweise das Enterprise Manager Repository. (Obligatorisch) 3 Vgl. [MSDN1] 4 Vgl. [Ahrends06] Seite 101

9 2 Architektur-Vergleich 9 TEMP: Der temporäre Tablespace wird verwendet, wenn eine SQL- Anweisung ausgeführt wird, bei der temporäre Segmente erstellt werden müssen (z. B. bei einer umfangreichen Sortierung oder einer Indexerstellung) 5. UNDOTBS: Ein Undo-Tablespace beinhaltet ausschließlich Undo-Segmente, deren Aufgabe es ist, den alten Zustand von Feldinhalten (before images) so lange zu speichern, bis der neue Zustand in der Datenbank festgeschrieben wurde. USERS: In diesem Tablespace werden permanente Benutzerobjekte und -daten gespeichert. SQL Server-Dateigruppen Jede Datendatei wird zu Verwaltungs- und Zuordnungszwecken in einer Dateigruppe gespeichert 6. Durch die Aufteilung der Daten auf mehrere Dateien und Dateigruppen können diese separat gesichert (Dateigruppensicherung) und wiederhergestellt werden. Jede Datei kann jeweils nur einer Dateigruppe angehören. Es gibt zwei Arten von Dateigruppen: Primäre Dateigruppe: Enthält die primäre Datendatei und alle anderen Dateien, die nicht explizit einer anderen Dateigruppe zugewiesen sind. Alle Seiten für die Systemtabellen werden in der primären Dateigruppe zugeordnet. Benutzerdefinierte Dateigruppe: Alle Dateigruppen, die mit Hilfe des FILEGROUP-Schlüsselwortes in der Anweisung CREATE DATABASE oder ALTER DATABASE angegeben werden. SQL Server-Systemdatenbanken In SQL Server wird eine Reihe von Datenbanken auf Systemebene verwendet die Systemdatenbanken, die für den Betrieb einer Serverinstanz von entscheidender Bedeutung sind. Jede SQL Server-Datenbank enthält die folgenden Systemdatenbanken: master-datenbank: Zeichnet alle Informationen auf Systemebene für eine Instanz von SQL Server auf. Dazu gehören Metadaten wie Anmeldekonten, Endpunkte, Verbindungsserver und Systemkonfigurationseinstellungen. 5 Vgl. [Best05] Kapitel 5, Seite 15 6 Vgl. [MSOD2]

10 2 Architektur-Vergleich 10 msdb-datenbank: Wird von SQL Server-Agent verwendet, um Termine für Warnungen und Aufträge zu planen. tempdb-datenbank: Ein Arbeitsbereich zum Speichern von temporären Objekten oder Zwischenresultsets. Die tempdb-systemdatenbank ist eine globale Ressource, die für alle Benutzer verfügbar ist, die mit der Instanz von SQL Server verbunden sind. Ressourcendatenbank: Eine schreibgeschützte Datenbank, die alle Systemobjekte enthält, die in SQL Server enthalten sind. model-datenbank: Wird als Vorlage für alle Datenbanken verwendet, die für die Instanz von SQL Server erstellt werden. Schema-Objekte Abschließend werden in der nachfolgenden Tabelle noch einmal einige Schema-Objekte dieser beiden Datenbanken verglichen. Weitere Schema- Objekte werden in Abschnitt 3.2 besprochen: Schema-Objekte von Oracle und SQL-Server Oracle SQL Server Datenbank Datenbank Schema Datenbank und Datenbankbesitzer (DBO) Tablespace Dateigruppe Benutzer Benutzer Rolle Gruppe/Rolle Tabelle Tabelle Temporäre Tabellen Temporäre Tabellen Cluster <nicht unterstützt> Column-level check constraint Column-level check constraint Column default Column default Unique-Schlüssel Unique-Schlüssel oder Identitätsmerkmal für die Zeile Primärschlüssel Primärschlüssel Fremdschlüssel Fremdschlüssel PL/SQL Prozedur T-SQL Gespeicherte Prozedur

11 2 Architektur-Vergleich 11 PL/SQL Funktion T-SQL Funktion Snapshot <nicht unterstützt> View View Tabelle 1: Schema-Objekte von Oracle und SQL-Server Instanzen Oracle-Instanz Ein Oracle-Datenbank-Server besteht aus einer Oracle-Datenbank und einer Oracle-Instanz 7. Oracle-Instanzen bestehen aus Memory-Strukturen, die als System Global Area (SGA) bezeichnet werden, sowie aus Hintergrundprozessen. Die Kombination aus SGA und Oracle- Hintergrundprozessen wird als Oracle-Instanz bezeichnet. Oracle-Instanzen sind immer mit einer einzelnen Datenbank verknüpft. Unter bestimmten Umständen können aber auch Oracle-Datenbanken mehrere Instanzen besitzen. SQL Server-Instanz Jede SQL Server-Instanz besteht aus einem Satz von Diensten mit bestimmten Einstellungen für Sortierungen und andere Optionen 8. Bei der Instanz kann es sich um eine Standardinstanz oder um eine benannte Instanz handeln. SQL Server-Instanzen können mit vielen Datenbanken verknüpft sein, wobei jede Instanz unabhängig von den anderen Instanzen ausgeführt wird. Zwar unterstützt der SQL Server 2005 mehrere Instanzen von SQL Server auf einem einzelnen Server oder Prozessor aber die Standardinstanz kann nur eine Instanz sein, alle anderen Instanzen müssen benannte Instanzen sein. 7 Vgl. [Best05] Kapitel 1, Seite 13 8 Vgl. [MSOD3]

12 3 Datenbankobjekte 12 3 Datenbankobjekte 3.1 Datentypzuordnungen Oracle-Datentypen und SQL Server-Datentypen stimmen nicht immer exakt überein. Für Fälle, in denen eine einzelne Datentypzuordnung unklar ist, gibt es noch alternative Datentypzuordnungen 9. Doch vorerst sollte überprüft werden, ob der SQL Server signifikantere Datentypen anbietet, damit nicht nachteilige Datentypen weiter verwendet werden. Weiterhin ist darauf zu achten, dass die Wertebereiche entweder identisch oder größer als die in Oracle verwendeten Datentypen sein müssen. Die folgende Tabelle zeigt die standardmäßige Zuordnung von Datentypen von Oracle zu SQL Server. Die Spalte "Alternativen" gibt an, ob alternative Zuordnungen verfügbar sind: Datentypzuordnungen von Oracle zu SQL Server Oracle-Datentyp SQL Server-Datentyp Alternativen BFILE VARBINARY(MAX) Ja BLOB VARBINARY(MAX) Ja CHAR([1-2000]) CHAR([1-2000]) Ja CLOB VARCHAR(MAX) Ja DATE DATETIME Ja FLOAT FLOAT Nein FLOAT([1-53]) FLOAT([1-53]) Nein FLOAT([54-126]) FLOAT Nein INT NUMERIC(38) Ja INTERVAL DATETIME Ja LONG VARCHAR(MAX) Ja LONG RAW IMAGE Ja NCHAR([1-1000]) NCHAR([1-1000]) Nein NCLOB NVARCHAR(MAX) Ja 9 [MSDN2]

13 3 Datenbankobjekte 13 LONG RAW IMAGE Ja NCHAR([1-1000]) NCHAR([1-1000]) Nein NCLOB NVARCHAR(MAX) Ja NUMBER FLOAT Ja NUMBER([1-38]) NUMERIC([1-38]) Nein NUMBER([0-38],[1-38]) NUMERIC([0-38],[1-38]) Ja NVARCHAR2([1-2000]) NVARCHAR([1-2000]) Nein RAW([1-2000]) VARBINARY([1-2000]) Nein REAL FLOAT Nein ROWID CHAR(18) Nein TIMESTAMP DATETIME Ja UROWID CHAR(18) Nein VARCHAR2([1-4000]) VARCHAR([1-4000]) Ja Tabelle 2: Datentypzuordnungen von Oracle zu SQL Server Die folgende Tabelle zeigt die standardmäßige Zuordnung von Datentypen von SQL Server zu Oracle: Datentypzuordnungen von SQL Server zu Oracle SQL Server-Datentyp Oracle-Datentyp BIGINT NUMBER(19,0) BINARY(1-2000) RAW(1-2000) BINARY( ) BLOB BIT NUMBER(1) CHAR(1-2000) CHAR(1-2000) CHAR( ) VARCHAR2( ) CHAR( ) CLOB DATETIME DATE DECIMAL(1-38, 0-38) NUMBER(1-38, 0-38) DOUBLE PRECISION FLOAT FLOAT FLOAT IMAGE BLOB INT NUMBER(10,0)

14 3 Datenbankobjekte 14 MONEY NUMBER(19,4) NCHAR(1-1000) CHAR(1-1000) NCHAR( ) NCLOB NTEXT NCLOB NUMERIC(1-38, 0-38) NUMBER(1-38, 0-38) NVARCHAR(1-1000) VARCHAR2(1-2000) NVARCHAR( ) NCLOB NVARCHAR(MAX) NCLOB REAL REAL SMALLDATETIME DATE SMALLINT NUMBER(5,0) SMALLMONEY NUMBER(10,4) SQL_VARIANT <nicht unterstützt> SYSNAME VARCHAR2(128) TEXT CLOB TIMESTAMP RAW(8) TINYINT NUMBER(3,0) UNIQUEIDENTIFIER CHAR(38) VARBINARY(1-2000) RAW(1-2000) VARBINARY( ) BLOB VARCHAR(1-4000) VARCHAR2(1-4000) VARCHAR( ) CLOB VARBINARY(MAX) BLOB VARCHAR(MAX) CLOB XML NCLOB Tabelle 3: Datentypzuordnungen von SQL Server zu Oracle Datum Während in SQL Server die Datentypen DATETIME und SMALLDATETIME für Datums- und Tageszeitangaben benutzt werden, stellt Oracle die Datentypen TIMESTAMP und DATE zur Verfügung 10 : 10 [MurDOC]

15 3 Datenbankobjekte 15 Datums- und Zeitangaben in SQL Server Datentyp Bereich Genauigkeit DATETIME SMALL- DATETIME Zwischen dem 1. Januar 1753 und dem 31. Dezember Zwischen dem 1. Januar 1900 und dem 6. Juni ,33 Millisekunden 1 Minute Tabelle 4: Datums- und Zeitangaben in SQL Server Datums- und Zeitangaben in Oracle Datentyp Bereich Genauigkeit TIME- STAMP DATE Zwischen dem 1. Januar 4712 v. Chr. und dem 31. Dezember 9999 n. Chr. Zwischen dem 1. Januar 4712 v. Chr. und dem 31. Dezember 9999 n. Chr. Ein einhundertmillionstel (1/ ) einer Sekunde 1 Sekunde Tabelle 5: Datums- und Zeitangaben in Oracle Datumskonvertierungen sollten manuell erstellt werden, weil Konvertierungsprogramme nicht die Logik hinter einer Tabelle verstehen können. Wenn beispielsweise eine Spalte Geburtstag mit dem Oracle-Datentyp DATE einer Tabelle Personen in eine Spalte mit dem SQL Server-Datentyp DATETIME konvertiert wird, dann werden diese Spalten noch mit überflüssigen Zeitangaben aufgeführt (Siehe Abschnitt 5.3). FLOAT und NUMBER Die Anzahl der Dezimalstellen (scale) und die Genauigkeit (precision), die während der Zuordnung der Datentypen FLOAT und NUMBER angegeben werden, sind von den Parametern abhängig, die in der Spalte der Oracle- Datenbank angegeben wurde, die diese Datentypen verwendet. Die Zahl 123,45 hat z. B. eine Genauigkeit von 5 (Ziffern) und 2 Dezimalstellen. Bei Oracle können Zahlen mit Werten für 'scale' größer als 'precision' definiert werden, z. B. NUMBER(4,5). In SQL Server muss jedoch 'precision' größer oder gleich 'scale' sein. Um sicherzustellen, dass keine Daten abgeschnitten werden, wenn bei Oracle 'scale' größer ist als 'precision', sollte

16 3 Datenbankobjekte 16 'precision' bei der Zuordnung auf denselben Wert festgelegt werden wie 'scale': NUMBER(4,5) wird also beispielsweise NUMERIC(5,5) zugeordnet 11. LOB-Typen (Large Object) Oracle unterstützt bis zu 4 Gigabyte (GB), SQL Server bis zu 2 GB 12. Daten aus Oracle, die über 2 GB sind, müssen deshalb abgeschnitten werden. Indizes Indizes müssen neu generiert werden, wobei geprüft werden sollte, welche Optimierungen in SQL Server möglich sind. NULL-Verhalten Unique Für Spalten, die von Unique-Einschränkungen betroffen sind, muss ein Wert ungleich NULL angegeben sein. Oracle und SQL Server verarbeiten NULL- Werte unterschiedlich: Oracle lässt mehrere Zeilen mit NULL-Werten für Spalten zu, bei denen NULL-Werte zulässig sind und die in UNIQUE- Einschränkungen oder -Indizes eingeschlossen sind. SQL Server erzwingt die Eindeutigkeit, indem nur eine einzige Zeile mit einem NULL-Wert für eine Spalte zulässig ist. ORDER BY-Klauseln Auch hier sollten einige Punkte über die unterschiedliche Behandlung von NULL-Werten in Oracle und SQL Server beachtet werden: o In SQL Server sind NULL-Werte die niedrigsten Werte in einer geordneten Liste. In einer aufsteigenden Liste stehen NULL-Werte an erster Stelle o In Oracle sind NULL-Werte die größten Werte in einer geordneten Liste. Als default stehen NULL-Werte in einer aufsteigenden Liste an erster Stelle [MSDN2]

17 3 Datenbankobjekte 17 ISNULL in String-Konkatenation Oracle und SQL Server geben unterschiedliche Ergebnisse zurück wenn in String-Konkatenationen NULL-Werte enthalten sind. Oracle behandelt die NULL-Werte wie einen leeren Zeichensatz, während der SQL Server NULL zurück gibt. Die folgende Tabelle zeigt, dass in Oracle NULL niemals äquivalent ist mit Null: NULL-Konstrukte in Oracle und SQL Server NULL-Konstrukt SQL Server Oracle where col1 = NULL datenabhängig FALSE where col1!= NULL datenabhängig TRUE where col1 IS NULL datenabhängig datenabhängig where col1 IS NOT NULL datenabhängig datenabhängig where NULL = NULL TRUE FALSE Tabelle 6: NULL-Konstrukte in Oracle und SQL Server Falls solche SQL Server-Abfragen vorliegen WHERE col1 = NULL sollten diese in solche Oracle-Abfragen umgeschrieben werden WHERE col1 IS NULL 3.2 Unterschiede zwischen ANSI-SQL und ORACLE- SQL Syntaxunterschiede Oracle Database 10g unterstützt den ANSI SQL:2003-Standard, während Microsoft SQL Server 2005 den ANSI SQL:1999-Standard unterstützt. Bei Oracle wird aber dennoch in der Praxis meistens die ORACLE-Syntax verwendet, die sich in entscheidenden Punkten von dem ANSI-Standard unterscheidet. Die folgende Tabelle zeigt die in Oracle und SQL Server verwendete unterschiedliche Syntax für dieselbe SQL-Anweisung:

18 3 Datenbankobjekte 18 SQL-Syntaxunterschiede Beschreibung Oracle SQL Server Left Outer Join Bis Oracle 9i nur: WHERE col1 = col2(+) Ab Oracle 9i: FROM tab1 LEFT OUTER JOIN tab2 ON tab1.col1 = tab2.col2 Right Outer Join Bis Oracle 9i nur: WHERE col1(+) = col2 Ab Oracle 9i: FROM tab1 RIGHT OUTER JOIN tab2 ON tab1.col1 = tab2.col2 Full Outer Join Ab Oracle 9i: FROM tab1 FULL OUTER JOIN tab2 ON tab1.col1 = tab2.col2 SELECT ohne SELECT 'hello world' FROM FROM DUAL; (Pseudo-Tabelle DUAL nötig) INSERT INSERT INTO [user.]{table [, column]...)]{values (expression [, expression]...) query...}; <INTO ist obligatorisch> Transformation CREATE TABLE... AS großer SELECT... Datenmengen Subtraktion SELECT... MINUS zweier SELECT... SELECTS FROM tab1 LEFT OUTER JOIN tab2 ON tab1.col1 = tab2.col2 FROM tab1 RIGHT OUTER JOIN tab2 ON tab1.col1 = tab2.col2 FROM tab1 FULL OUTER JOIN tab2 ON tab1.col1 = tab2.col2 SELECT 'hello world' oder SELECT 3*6 INSERT [INTO] [[database.]owner.] {table view}[(column [, column]...)]{values (expression [,expression]...) query} <INTO ist optional> SELECT... INTO SELECT... EXCEPT SELECT...

19 3 Datenbankobjekte 19 SELECT col1, col2, col3 INTO tab1 FROM tab2 WHERE... ALTER TABLE table_name DROP COLUMN column_name <nicht unterstützt> GRANT SELECT... IDENTITY (s, i) S = Anfangswert i = inkrementeller Wert Siehe Abschnitt 5.4 Lösungsmöglichkeit: Siehe Abschnitt 5.4 SAVE TRANSACTION TABLOCK, HOLDLOCK TABLOCKX, HOLDLOCK ROWLOCK, HOLDLOCK ROWLOCK, XLOCK, HOLDLOCK TABLOCK, XLOCK, HOLDLOCK SELECT INTO- INSERT INTO tab1 Anweisung SELECT col1,col2,col3 FROM tab2 WHERE... Spalte löschen Ab Oracle 8i: ALTER TABLE table_name DROP COLUMN column_name UNUSE Verschachtelte Ab Oracle 9i: Tabellen (nested NESTED TABLE tab1 tables) store AS tab2 Readonly VIEW CREATE VIEW... WITH READONLY Sequence CREATE SEQUENCE seq_name... Synonym CREATE SYNONYM s_name FOR obj_name; Sicherungspunkt SAVEPOINT festlegen Lockmodi SHARE EXCLUSIVE ROW SHARE SHARE UPDATE = ROW SHARE ROW EXCLUSIVE SHARE ROW EXCLUSIVE Lockmode- Optionen Zeitspanne zur Aufhebung einer Sperre festlegen Reservierung des Indexbereichs ROW-Level PARTITION, NOWAIT Keine Zeitspannenangabe möglich, außer NOWAIT agiert wie "LOCK_TIMEOUT 0" PCTFREE=0 <keine Entsprechung> <nicht unterstützt> SET LOCK_TIMEOUT timeout_period FILLFACTOR=100

20 3 Datenbankobjekte 20 DESCRIBE DESCRIBE table_name sp_help oder sp_columns (SQLPlus-Befehl) Pseudospalte ROWID SELECT ROWID, SUBSTR(ROWID, 1, 6) object,... <keine Entsprechung> Lösungsmöglichkeit: Siehe Abschnitt 5.4 Pseudospalte ROWNUM SELECT ROWNUM, empno, ename FROM scott.emp e... <keine Entsprechung> Lösungsmöglichkeit: Siehe Abschnitt 5.4 Spalten-Alias SELECT col1 employees FROM table SELECT employees=col1 FROM table Alias SELECT name alias_name SELECT name AS alias_name Tabelle 7: SQL-Syntaxunterschiede 13 Syntaxunterschiede der prozeduralen Spracherweiterungen PL/SQL und T-SQL sind rein herstellerbezogene prozedurale Erweiterungen des SQL-Standards. Sie bieten zwar viele derselben Konstrukte aber haben jedoch außer die Grundkonzeption und Funktionalität betreffend hinsichtlich der Sprachsyntax nicht allzu viele Gemeinsamkeiten. Die folgende Tabelle zeigt einige Syntaxunterschiede von PL/SQL und T-SQL: Syntaxunterschiede von PL/SQL und T-SQL Beschreibung Oracle PL/SQL SQL Server T-SQL Lokale Variable DECLARE var_name type <nicht unterstützt> in DECLARE initialisieren := value; Konstante DECLARE var_name <nicht unterstützt> deklarieren CONSTANT type := value; Variable zuweisen Var_name := value SELECT value INTO = value = value var_name %TYPE DECLARE guthaben NUMBER(7,2); schuld guthaben%type; <nicht unterstützt> 13 Vgl. [MSTN1]

21 3 Datenbankobjekte 21 Collection Cursor deklarieren Cursor in eine Variable zuweisen Cursor öffnen Cursorverweis entfernen If-Anweisung TYPE type_name IS TABLE OF element_type [NOT NULL]; CURSOR cur_name (params) IS SELECT; FETCH cur_name INTO var_name OPEN cur_name (params); <nicht erforderlich> IF... THEN, ELSIF... THEN, ELSE, ENDIF; <nicht unterstützt> Lösungsmöglichkeit: Siehe Abschnitt 5.3 DECLARE cur_name CURSOR (params) FOR SELECT FETCH (params) FROM cur_name OPEN cur_name DEALLOCATE cur_name IF... [BEGIN... END] ELSE... [BEGIN... END] ELSE IF... CASE... While-Schleife Schleifenkontrolle Schleifenabbruch While-Schleifen- Neustart Print output Raise error Pakete Trigger Alternativ: CASE WHEN... THEN...; ELSE... ; END CASE; WHILE... LOOP END LOOP; FOR... END LOOP; LOOP... END LOOP; EXIT, EXIT WHEN <nicht unterstützt> Realisiert über die Funktion: DBMS_OUTPUT.PUT_LINE RAISE_APPLICATION_ERRO R CREATE OR REPLACE PACKAGE package_name BEFORE TRIGGER AFTER TRIGGER INSTEAD OF TRIGGER ROW LEVEL TRIGGER WHILE... [BEGIN... END] <nicht unterstützt> BREAK CONTINUE PRINT RAISERROR <nicht unterstützt> Siehe Abschnitt 5.4 INSTEAD OF TRIGGER AFTER TRIGGER INSTEAD OF TRIGGER imitiert durch CURSOR Abschlusszeichen Semikolon (;) <nicht erforderlich> Tabelle 8: Syntaxunterschiede von PL/SQL und T-SQL

22 3 Datenbankobjekte 22 Über weitere Möglichkeiten für Syntaxzuordnungen und Lösungsmöglichkeiten für einige in SQL Server nicht unterstützte Syntaxzuordnungen sei nochmals auf Abschnitt 5.4 verwiesen. Operatoren Die meisten Operatoren in Oracle und SQL Server stimmen überein. Hier nur ein Operator, der sich unterscheidet 14 : Operatorunterschiede Beschreibung Oracle SQL Server Konkatenation string1 string2 string1 + string2 Tabelle 9: Operatorunterschiede 3.3 Namenskollisionen Reservierte Schlüsselwörter Beide Datenbankmanagementsysteme verwenden eine Fülle von reservierten Schlüsselwörtern zum Definieren, Bearbeiten und Zugreifen auf Datenbanken 15. Keine dieser reservierten Schlüsselwörter sollten für Objektnamen (Tabellen, Indizes, Views, ) und Objektbezeichner verwendet werden. Doch einige Objekte, die ursprünglich in Oracle erstellt wurden, könnten Benennungen aufweisen, die für reservierte Schlüsselwörter in SQL Server verwendet werden. Damit keine Namenskollisionen auftreten, sollten diese Objektnamen und Objektbezeichner vor einer Migration umbenannt werden. Die folgende Tabelle führt reservierte Schlüsselwörter von SQL Server auf, die aber in Oracle als Objektnamen und bezeichner verwendet werden dürfen, da sie in Oracle nicht als reservierte Schlüsselwörter deklariert wurden 16 : 14 Vgl. [MSTN1] 15 Vgl. [MSDN3] 16 Vergleiche hierzu alle reservierten Schlüsselwörter in der Oracle-Onlinedokumentation unter [OraDOC1] und [OraDOC2]

23 3 Datenbankobjekte 23 Reservierte Schlüsselwörter des SQL Server BROWSE IDENTITY READTEXT CLUSTERED IDENTITY_INSERT RECONFIGURE COLLATE IDENTITYCOL REPLICATION COMPUTE INNER RESTORE CONTAINS KILL RESTRICT CONTAINSTABLE LEFT REVERT CROSS LINENO ROWCOUNT CURRENT_DATE LOAD ROWGUIDCOL CURRENT_TIME NOCHECK RULE CURRENT_TIMESTAMP NONCLUSTERED SESSION_USER CURRENT_USER OFFSETS SETUSER DBCC OPENDATASOURCE SYSTEM_USER DEALLOCATE OPENQUERY TABLESAMPLE DENY OPENROWSET TEXTSIZE DISK OPENXML TOP DISTRIBUTED OUTER TRAN DUMMYRECONFIGURE OVER TSEQUAL FILLFACTOR PERCENT UNPIVOT FREETEXT PIVOT UPDATETEXT FREETEXTTABLE PRINT WAITFOR FULL PROC WRITETEXT HOLDLOCK RAISERROR Tabelle 10: Reservierte Schlüsselwörter des SQL Server Reservierte ODBC-Schlüsselwörter Die folgenden Wörter sind für die Verwendung in ODBC-Funktionsaufrufen reserviert. Damit in SQL Server die Kompatibilität mit Treibern sichergestellt ist, die die zentrale (core) SQL-Grammatik unterstützen, sollten diese Schlüsselwörter nicht in dem Quellsystem als Objektnamen und bezeichner auftauchen 17. Diese Tabelle listet die reservierten ODBC-Schlüsselwörter des SQL Server auf, die in Oracle nicht als reservierte Schlüsselwörter auftreten: Reservierte ODBC-Schlüsselwörter des SQL Server ABSOLUTE DIAGNOSTICS PAD ACTION DISCONNECT PARTIAL ADA DOMAIN POSITION ARE END-EXEC PREPARE 17 [MSDN3]

SQL (Structured Query Language) Schemata Datentypen

SQL (Structured Query Language) Schemata Datentypen 2 SQL Sprachelemente Grundlegende Sprachelemente von SQL. 2.1 Übersicht Themen des Kapitels SQL Sprachelemente Themen des Kapitels SQL (Structured Query Language) Schemata Datentypen Im Kapitel SQL Sprachelemente

Mehr

Datenbanken Konsistenz und Mehrnutzerbetrieb III

Datenbanken Konsistenz und Mehrnutzerbetrieb III Datenbanken Konsistenz und Mehrnutzerbetrieb III 1. Oracle Architektur! Komponenten des Oracle Servers! Zugriff über Netzwerk 2. Zugriffsrechte! Starten und Schließen der Datenbank! Nutzer und Rollen!

Mehr

Whitepaper. Produkt: combit Relationship Manager. Datensatzhistorie mit dem SQL Server 2000 und 2005. combit GmbH Untere Laube 30 78462 Konstanz

Whitepaper. Produkt: combit Relationship Manager. Datensatzhistorie mit dem SQL Server 2000 und 2005. combit GmbH Untere Laube 30 78462 Konstanz combit GmbH Untere Laube 30 78462 Konstanz Whitepaper Produkt: combit Relationship Manager Datensatzhistorie mit dem SQL Server 2000 und 2005 Datensatzhistorie mit dem SQL Server 2000 und 2005-2 - Inhalt

Mehr

Themen des Kapitels. 2 Grundlagen von PL/SQL. PL/SQL Blöcke Kommentare Bezeichner Variablen Operatoren. 2.1 Übersicht. Grundelemente von PL/SQL.

Themen des Kapitels. 2 Grundlagen von PL/SQL. PL/SQL Blöcke Kommentare Bezeichner Variablen Operatoren. 2.1 Übersicht. Grundelemente von PL/SQL. 2 Grundlagen von PL/SQL Grundelemente von PL/SQL. 2.1 Übersicht Themen des Kapitels Grundlagen von PL/SQL Themen des Kapitels PL/SQL Blöcke Kommentare Bezeichner Variablen Operatoren Im Kapitel Grundlagen

Mehr

Inhalt. Ein Einführung in die Nutzung von SQL-Datenbanken am Beispiel Oracle. Daten und Tabellen - ein Beispiel. Daten und Tabellen - Normalisierung

Inhalt. Ein Einführung in die Nutzung von SQL-Datenbanken am Beispiel Oracle. Daten und Tabellen - ein Beispiel. Daten und Tabellen - Normalisierung Inhalt Ein Einführung in die Nutzung von SQL-Datenbanken am Beispiel Oracle Daten und Tabellen Normalisierung, Beziehungen, Datenmodell SQL - Structured Query Language Anlegen von Tabellen Datentypen (Spalten,

Mehr

1 Transaktionen in SQL. 2 Was ist eine Transaktion. 3 Eigenschaften einer Transaktion. PostgreSQL

1 Transaktionen in SQL. 2 Was ist eine Transaktion. 3 Eigenschaften einer Transaktion. PostgreSQL 1 Transaktionen in SQL Um Daten in einer SQL-Datenbank konsistent zu halten, gibt es einerseits die Möglichkeit der Normalisierung, andererseits sog. Transaktionen. 2 Was ist eine Transaktion Eine Transaktion

Mehr

Inhaltsverzeichnis. jetzt lerne ich

Inhaltsverzeichnis. jetzt lerne ich Inhaltsverzeichnis jetzt lerne ich Einführung 15 1 Erste Schritte 21 1.1 Datenbanken und Datenbank-Managementsysteme 21 1.2 Zugriff auf Datenbanken 22 1.3 Was der Großvater noch wusste... 22 1.4 Einordnung

Mehr

Prozedurale Datenbank- Anwendungsprogrammierung

Prozedurale Datenbank- Anwendungsprogrammierung Idee: Erweiterung von SQL um Komponenten von prozeduralen Sprachen (Sequenz, bedingte Ausführung, Schleife) Bezeichnung: Prozedurale SQL-Erweiterung. In Oracle: PL/SQL, in Microsoft SQL Server: T-SQL.

Mehr

www.informatik-aktuell.de

www.informatik-aktuell.de www.informatik-aktuell.de Flashback Reise in die Vergangenheit einfach. gut. beraten. Warum Oracle Zeitreisen anbieten kann, der Microsoft SQL Server aber leider nicht. IT-Tage Datenbanken 18.12.2015,

Mehr

3 Indizes. 3.1 Indexarchitektur von SQL Server. SQL Server 2008: Datenbankentwicklung

3 Indizes. 3.1 Indexarchitektur von SQL Server. SQL Server 2008: Datenbankentwicklung 3 Indizes 3.1 Indexarchitektur von SQL Server Die folgende Abbildung zeigt die Organisationsstruktur einer Tabelle. Eine Tabelle befindet sich in einer oder mehreren Partitionen, und jede Partition enthält

Mehr

Hochschule Karlsruhe Technik und Wirtschaft- 10.7.2013. Anhänge: Fakultät für Informatik und Wirtschaftsinformatik SS 2013 Prof. Schmidt.

Hochschule Karlsruhe Technik und Wirtschaft- 10.7.2013. Anhänge: Fakultät für Informatik und Wirtschaftsinformatik SS 2013 Prof. Schmidt. Fakultät für Informatik und Wirtschaftsinformatik SS 2013 Datenbanken und Informationssysteme II Szenario: Projektverwaltung. Es gibt Projekte, Projektleiter, Mitarbeiter und ihre Zuordnung zu Projekten.

Mehr

Datenbanken II Speicherung und Verarbeitung großer Objekte (Large Objects [LOBs])

Datenbanken II Speicherung und Verarbeitung großer Objekte (Large Objects [LOBs]) Datenbanken II Speicherung und Verarbeitung großer Objekte (Large Objects [LOBs]) Hochschule für Technik, Wirtschaft und Kultur Leipzig 06.06.2008 Datenbanken II,Speicherung und Verarbeitung großer Objekte

Mehr

WS 2010/11 Datenbanksysteme Fr 15:15 16:45 R 1.008. Vorlesung #6. SQL (Teil 4)

WS 2010/11 Datenbanksysteme Fr 15:15 16:45 R 1.008. Vorlesung #6. SQL (Teil 4) Vorlesung #6 SQL (Teil 4) Fahrplan Besprechung der Übungsaufgaben Einschub: Self Joins (relevant fürs Praktikum) Dynamische Intergritätsbedingungen, das Trigger - Konzept von Oracle Prozedurale Erweiterungen,

Mehr

SQL für Trolle. mag.e. Dienstag, 10.2.2009. Qt-Seminar

SQL für Trolle. mag.e. Dienstag, 10.2.2009. Qt-Seminar Qt-Seminar Dienstag, 10.2.2009 SQL ist......die Abkürzung für Structured Query Language (früher sequel für Structured English Query Language )...ein ISO und ANSI Standard (aktuell SQL:2008)...eine Befehls-

Mehr

MySQL, phpmyadmin & SQL. Kurzübersicht

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

Mehr

Whitepaper. Produkt: combit Relationship Manager / address manager. FILESTREAM für Microsoft SQL Server aktivieren

Whitepaper. Produkt: combit Relationship Manager / address manager. FILESTREAM für Microsoft SQL Server aktivieren combit GmbH Untere Laube 30 78462 Konstanz Whitepaper Produkt: combit Relationship Manager / address manager FILESTREAM für Microsoft SQL Server aktivieren FILESTREAM für Microsoft SQL Server aktivieren

Mehr

Sructred Query Language

Sructred Query Language Sructred Query Language Michael Dienert 11. November 2010 Inhaltsverzeichnis 1 Ein kurzer Versionsüberblick 1 2 SQL-1 mit einigen Erweiterungen aus SQL-92 2 3 Eine Sprache zur Beschreibung anderer Sprachen

Mehr

17.2 MS-Access Projekte

17.2 MS-Access Projekte 964 Von MS-Access 2000 zum SQL-Server 17.2 MS-Access Projekte MS-Access-Projekte, die die Dateiendung adp besitzen, werden als Front-End-Anwendung verwendet. Für die Back-End-Seite gibt es mehrere Möglichkeiten.

Mehr

Funktion definieren Gibt Summe der Gehälter zurück. Aufruf in einem SQL-Statement

Funktion definieren Gibt Summe der Gehälter zurück. Aufruf in einem SQL-Statement Funktion definieren Gibt Summe der Gehälter zurück Aufruf in einem SQL-Statement Dr. Christian Senger Einführung PL/SQL 1 Procedures & Transaktionen CREATE OR REPLACE PROCEDURE write_log ( log_code IN

Mehr

Datumsangaben, enthält mindestens Jahr, Monat, Tag

Datumsangaben, enthält mindestens Jahr, Monat, Tag Datenbanken mit SQL Informatik - Sprenger Häufig wird mit Tabellenkalkulationen gearbeitet, obwohl der Einsatz von Datenbanken sinnvoller ist. Tabellenkalkulationen wie Microsoft Excel oder LibreOffice

Mehr

Kapitel 33. Der xml-datentyp. In diesem Kapitel: Der xml-datentyp 996 Abfragen aus xml-datentypen 1001 XML-Indizierung 1017 Zusammenfassung 1023

Kapitel 33. Der xml-datentyp. In diesem Kapitel: Der xml-datentyp 996 Abfragen aus xml-datentypen 1001 XML-Indizierung 1017 Zusammenfassung 1023 Kapitel 33 Der xml-datentyp In diesem Kapitel: Der xml-datentyp 996 Abfragen aus xml-datentypen 1001 XML-Indizierung 1017 Zusammenfassung 1023 995 996 Kapitel 33: Der xml-datentyp Eine der wichtigsten

Mehr

Powerful PL/SQL: Collections indizieren mit VARCHAR2- Indizes ein Praxisbeispiel

Powerful PL/SQL: Collections indizieren mit VARCHAR2- Indizes ein Praxisbeispiel Powerful PL/SQL: Collections indizieren mit VARCHAR2- Indizes ein Praxisbeispiel Schlagworte Autor: Klaus Friemelt, MT AG dynamisches BULK SQL, VARCHAR2-indizierte PL/SQL-Tabellen Einleitung Mit den letzten

Mehr

15 Bilder und Dateien im SQL Server

15 Bilder und Dateien im SQL Server Leseprobe aus Access und SQL Server http://www.acciu.de/asqllesen 15 Bilder und Dateien im SQL Server Eines der großen Probleme von Access-Datenbanken ist der vergleichsweise geringe Speicher platz. Sicher,

Mehr

Datenbankadministration

Datenbankadministration Datenbankadministration 11. Synchronisation AG DBIS University of Kaiserslautern, Germany Karsten Schmidt kschmidt@informatik.uni-kl.de (Vorlage TU-Dresden) Wintersemester 2008/2009 Transaktion Transaktion

Mehr

Datenintegrität und Transaktionskonzept

Datenintegrität und Transaktionskonzept und Transaktionskonzept 1. / Datenkonsistenz 1 Mögliche Gefährdung der : Missachtung von Konsistenzbedingungen ("Semantische Integrität") Inkorrekte Verweise auf Datensätze in verschiedenen Tabellen ("Referentielle

Mehr

SQL. SQL: Structured Query Language. Früherer Name: SEQUEL. Standardisierte Anfragesprache für relationale DBMS: SQL-89, SQL-92, SQL-99

SQL. SQL: Structured Query Language. Früherer Name: SEQUEL. Standardisierte Anfragesprache für relationale DBMS: SQL-89, SQL-92, SQL-99 SQL Früherer Name: SEQUEL SQL: Structured Query Language Standardisierte Anfragesprache für relationale DBMS: SQL-89, SQL-92, SQL-99 SQL ist eine deklarative Anfragesprache Teile von SQL Vier große Teile:

Mehr

Einführung in SQL Datenbanken bearbeiten

Einführung in SQL Datenbanken bearbeiten Einführung in SQL Datenbanken bearbeiten Jürgen Thomas Entstanden als Wiki-Buch Bibliografische Information Diese Publikation ist bei der Deutschen Nationalbibliothek registriert. Detaillierte Angaben

Mehr

Datenbanksystem. System Global Area. Hintergrundprozesse. Dr. Frank Haney 1

Datenbanksystem. System Global Area. Hintergrundprozesse. Dr. Frank Haney 1 Datenbanksystem System Global Area Hintergrundprozesse Dr. Frank Haney 1 Komponenten des Datenbanksystems System Global Area Program Global Area Hintergrundprozesse Dr. Frank Haney 2 System Global Area

Mehr

Transaktionen in der Praxis. Dr. Karsten Tolle

Transaktionen in der Praxis. Dr. Karsten Tolle Transaktionen in der Praxis Dr. Karsten Tolle Praxisbeispiel in Java Connection con = null; try { con = DriverManager.getConnection("jdbc:db2:sample"); } catch (Exception e) { e.printstacktrace(); } con.setautocommit(false);

Mehr

Views in SQL. 2 Anlegen und Verwenden von Views 2

Views in SQL. 2 Anlegen und Verwenden von Views 2 Views in SQL Holger Jakobs bibjah@bg.bib.de, holger@jakobs.com 2010-07-15 Inhaltsverzeichnis 1 Wozu dienen Views? 1 2 Anlegen und Verwenden von Views 2 3 Schreibfähigkeit von Views 3 3.1 Views schreibfähig

Mehr

Bibliografische Informationen digitalisiert durch http://d-nb.info/995021198

Bibliografische Informationen digitalisiert durch http://d-nb.info/995021198 Auf einen Blick 1 Einleitung 15 2 Datenbankentwurf 23 3 Datenbankdefinition 43 4 Datensätze einfügen (INSERT INTO) 95 5 Daten abfragen (SELECT) 99 6 Daten aus mehreren Tabellen abfragen (JOIN) 143 7 Unterabfragen

Mehr

Fachhochschule Kaiserslautern Labor Datenbanken mit MySQL SS2006 Versuch 1

Fachhochschule Kaiserslautern Labor Datenbanken mit MySQL SS2006 Versuch 1 Fachhochschule Kaiserslautern Fachbereiche Elektrotechnik/Informationstechnik und Maschinenbau Labor Datenbanken Versuch 1 : Die Grundlagen von MySQL ------------------------------------------------------------------------------------------------------------

Mehr

Fakultät für Informatik & Wirtschaftsinformatik DB & IS II - SS 2015. Metadaten

Fakultät für Informatik & Wirtschaftsinformatik DB & IS II - SS 2015. Metadaten Fakultät für Informatik & Wirtschaftsinformatik Metadaten Metadaten sind Daten über Daten Data-Dictionary speichert Informationen über die Struktur der Daten, z.b.: Tabellen, Spalten, Datentypen Primär-

Mehr

SQL-Anweisungen. SELECT (SQL Data Query Language)

SQL-Anweisungen. SELECT (SQL Data Query Language) SQL-Anweisungen SELECT (SQL Data Query Language) SELECT * SELECT * FROM "meine Tabelle"; SELECT feldname1, feldname2 SELECT feldname1, feldname2 FROM meinetabelle ORDER BY feldname2, feldname1 DESC; WHERE

Mehr

Uni Duisburg-Essen Fachgebiet Informationssysteme Prof. Dr. N. Fuhr

Uni Duisburg-Essen Fachgebiet Informationssysteme Prof. Dr. N. Fuhr Raum: LF 230 Bearbeitung: 9.-11. Mai 2005 Datum Gruppe Vorbereitung Präsenz Aktuelle Informationen unter: http://www.is.informatik.uni-duisburg.de/courses/dbp_ss03/ Tabellen in IBM DB2 Tabellen Eine relationale

Mehr

Objektrelationale und erweiterbare Datenbanksysteme

Objektrelationale und erweiterbare Datenbanksysteme Objektrelationale und erweiterbare Datenbanksysteme Erweiterbarkeit SQL:1999 (Objekt-relationale Modellierung) In der Vorlesung werden nur die Folien 1-12 behandelt. Kapitel 14 1 Konzepte objekt-relationaler

Mehr

In Tabelle 2.1 sehen Sie das Ergebnis beider Ausführungen auf meiner Maschine.

In Tabelle 2.1 sehen Sie das Ergebnis beider Ausführungen auf meiner Maschine. Kapitel 2 Datenverwaltung durch SQL Server Wir wollen das obige Skript zwei Mal laufen lassen, einmal mit und einmal ohne eingeschalteten Schreibcache der Festplatte. Für eine lokale Festplatte können

Mehr

3.17 Zugriffskontrolle

3.17 Zugriffskontrolle 3. Der SQL-Standard 3.17. Zugriffskontrolle Seite 1 3.17 Zugriffskontrolle Datenbanken enthalten häufig vertrauliche Informationen, die nicht jedem Anwender zur Verfügung stehen dürfen. Außerdem wird man

Mehr

SQL structured query language

SQL structured query language Umfangreiche Datenmengen werden üblicherweise in relationalen Datenbank-Systemen (RDBMS) gespeichert Logische Struktur der Datenbank wird mittels Entity/Realtionship-Diagrammen dargestellt structured query

Mehr

Aufbau einer Oracle Datenbank Tablespace, Arten von Dateien

Aufbau einer Oracle Datenbank Tablespace, Arten von Dateien Aufbau einer Oracle Datenbank Tablespace, Arten von Dateien Boris Meißner 05-INDT Fachbereich Informatik, Mathematik und Naturwissenschaften HTWK-Leipzig 05. Juni 2008 Boris Meißner (Fb IMN - HTWK-Leipzig)

Mehr

26.1.1 Vor- und Nachteile speicheroptimierter Tabellen... 764

26.1.1 Vor- und Nachteile speicheroptimierter Tabellen... 764 25.4 Verhalten bei Systemfehlern... 735 25.5 Programmierung expliziter Transaktionen... 737 25.6 Implizite Transaktionen... 741 25.7 Sperren... 743 25.7.1 Sperrebenen... 743 25.7.2 Gemeinsame Sperren (Shared

Mehr

Datenbanken. 5 Tabellen. Karl Meier karl.meier@kasec.ch 12.10.2010. Inhalt. Domänen verwenden Tabellen anzeigen, ändern, löschen Übung

Datenbanken. 5 Tabellen. Karl Meier karl.meier@kasec.ch 12.10.2010. Inhalt. Domänen verwenden Tabellen anzeigen, ändern, löschen Übung Datenbanken 5 Tabellen Karl Meier karl.meier@kasec.ch 12.10.2010 Tabellen erstellen en Integritätsregeln Inhalt Domänen verwenden Tabellen anzeigen, ändern, löschen Übung 2 1 Einfache Tabellen erstellen

Mehr

SQL. Fortgeschrittene Konzepte Auszug

SQL. Fortgeschrittene Konzepte Auszug SQL Fortgeschrittene Konzepte Auszug Levels SQL92 Unterteilung in 3 Levels Entry Level (i.w. SQL89) wird von nahezu allen DBS Herstellern unterstützt Intermediate Level Full Level SQL DML 2-2 SQL92 behebt

Mehr

7. Datenbank-Zugriff. Vorlesung und Übung Dr. Peter Pfahler Institut für Informatik Universität Paderborn. Zum Beispiel aus PHP-Skripten: Client 7-2

7. Datenbank-Zugriff. Vorlesung und Übung Dr. Peter Pfahler Institut für Informatik Universität Paderborn. Zum Beispiel aus PHP-Skripten: Client 7-2 5 Vorlesung und Übung Dr. Peter Pfahler Institut für Informatik Universität Paderborn 7 7. Datenbank-Zugriff Zum Beispiel aus PHP-Skripten: Client 7-2 Struktur einer Datenbank 7-3 Erzeugen von Datenbanken

Mehr

Cassandra Query Language (CQL)

Cassandra Query Language (CQL) Cassandra Query Language (CQL) Seminar: NoSQL Wintersemester 2013/2014 Cassandra Zwischenpräsentation 1 Gliederung Basic facts Datentypen DDL/DML ähnlich zu SQL Besonderheiten Basic facts CQL kurz für

Mehr

Stephan Arenswald stephan.arenswald@studentprogram.de

Stephan Arenswald stephan.arenswald@studentprogram.de Stephan Arenswald stephan.arenswald@studentprogram.de Know-how Transfer (.NET, Server, MBS, ) Zusatzqualifikation und Referenzen Weiterbildung neue Technologien Leichter Berufseinstieg/ Praktika Kontakte

Mehr

Dynamisches SQL. Folien zum Datenbankpraktikum Wintersemester 2009/10 LMU München

Dynamisches SQL. Folien zum Datenbankpraktikum Wintersemester 2009/10 LMU München Kapitel 4 Dynamisches SQL Folien zum Datenbankpraktikum Wintersemester 2009/10 LMU München 2008 Thomas Bernecker, Tobias Emrich unter Verwendung der Folien des Datenbankpraktikums aus dem Wintersemester

Mehr

PostgreSQL unter Debian Linux

PostgreSQL unter Debian Linux Einführung für PostgreSQL 7.4 unter Debian Linux (Stand 30.04.2008) von Moczon T. und Schönfeld A. Inhalt 1. Installation... 2 2. Anmelden als Benutzer postgres... 2 2.1 Anlegen eines neuen Benutzers...

Mehr

Übungsblatt 8- Lösungsvorschlag

Übungsblatt 8- Lösungsvorschlag Universität Innsbruck - Institut für Informatik Prof. Günther Specht, R.Binna, N.Krismer, M. Tschuggnall 30. November 2012 Proseminar Datenbanksysteme Übungsblatt 8- Lösungsvorschlag Aufgabe 1 (Trigger)

Mehr

Tag 4 Inhaltsverzeichnis

Tag 4 Inhaltsverzeichnis Tag 4 Inhaltsverzeichnis Normalformen Problem Formen (1-4) Weitere Formen Transaktionen Synchronisationsprobleme Überblick Autocommit Locking Savepoints Isolation levels Übungen RDB 4-1 Normalformen Problematik

Mehr

DATENBANKEN SQL UND SQLITE VON MELANIE SCHLIEBENER

DATENBANKEN SQL UND SQLITE VON MELANIE SCHLIEBENER DATENBANKEN SQL UND SQLITE VON MELANIE SCHLIEBENER INHALTSVERZEICHNIS 1. Datenbanken 2. SQL 1.1 Sinn und Zweck 1.2 Definition 1.3 Modelle 1.4 Relationales Datenbankmodell 2.1 Definition 2.2 Befehle 3.

Mehr

Einführung in SQL. Sprachumfang: Indizes. Datensätzen. Zugriffsrechten

Einführung in SQL. Sprachumfang: Indizes. Datensätzen. Zugriffsrechten Einführung in SQL Die Sprache SQL (Structured Query Language) ist eine Programmiersprache für relationale Datenbanksysteme, die auf dem ANSI-SQL-Standard beruht. SQL wird heute von fast jedem Datenbanksystem

Mehr

Datenbankentwicklung mit dem Microsoft SQL Server 2005

Datenbankentwicklung mit dem Microsoft SQL Server 2005 Holger Schmeling Datenbankentwicklung mit dem Microsoft SQL Server 2005 ISBN-10: 3-446-22532-3 ISBN-13: 978-3-446-22532-9 Inhaltsverzeichnis Weitere Informationen oder Bestellungen unter http://www.hanser.de/978-3-446-22532-9

Mehr

Einstellungen zur Verwendung von Flashback-Abfragen

Einstellungen zur Verwendung von Flashback-Abfragen Thema Autor REISE IN DIE VERGANGENHEIT Kamel Bouzenad (kamel.bouzenad@trivadis.com) Art der Info Infos für Entwickler und DBAs (April 2002) Quelle Oracle-Dokumentation sowie beratende Aktivitäten Überblick

Mehr

4.14.3 Bedingungen über Werte. 4.14.4 Statische Integrität. CHECK-Klausel

4.14.3 Bedingungen über Werte. 4.14.4 Statische Integrität. CHECK-Klausel 4.14.3 Bedingungen über Werte 4.14.4 Statische Integrität Zu jeder Tabelle werden typischerweise ein Primärschlüssel und möglicherweise weitere Schlüssel festgelegt (UNIQUE-Klausel). In jeder Instanz zu

Mehr

Isolationsstufen für. Dr. Karsten Tolle Dienstag 31. Januar 2012

Isolationsstufen für. Dr. Karsten Tolle Dienstag 31. Januar 2012 Isolationsstufen für Transaktionen / Sicherheit Dr. Karsten Tolle Dienstag 31. Januar 2012 Praxisbeispiel in Java Connection con = null; try { con = DriverManager.getConnection("jdbc:db2:sample"); } catch

Mehr

Datenbanksysteme. Dominic Pacher. Datenbanken und Informationssysteme (DBIS) Institut für Informatik Universität Innsbruck. dbis-informatik.uibk.ac.

Datenbanksysteme. Dominic Pacher. Datenbanken und Informationssysteme (DBIS) Institut für Informatik Universität Innsbruck. dbis-informatik.uibk.ac. Datenbanksysteme Dominic Pacher Datenbanken und Informationssysteme (DBIS) Institut für Informatik Universität Innsbruck dbis-informatik.uibk.ac.at 1 Übersicht Was passiert in den kommenden 90 Minuten?

Mehr

PL/SQL. Deklaration von Variablen. Inhalt. PL/SQL Block Struktur. PL/SQL Block Struktur

PL/SQL. Deklaration von Variablen. Inhalt. PL/SQL Block Struktur. PL/SQL Block Struktur PL/SQL Deklaration von Variablen Inhalt Erkennen der PL/SQL Blockstruktur Beschreiben von Variablen in PL/SQL Unterschied zwischen PL/SQL und nicht-pl/sql Variablen Deklaration von PL/SQL Variablen Ausführen

Mehr

Semantische Integrität (auch: Konsistenz) der in einer Datenbank gespeicherten Daten als wichtige Anforderung

Semantische Integrität (auch: Konsistenz) der in einer Datenbank gespeicherten Daten als wichtige Anforderung 6. Datenintegrität Motivation Semantische Integrität (auch: Konsistenz) der in einer Datenbank gespeicherten Daten als wichtige Anforderung nur sinnvolle Attributwerte (z.b. keine negativen Semester) Abhängigkeiten

Mehr

Datenbanken SQL Einführung Datenbank in MySQL einrichten mit PhpMyAdmin

Datenbanken SQL Einführung Datenbank in MySQL einrichten mit PhpMyAdmin Datenbanken SQL Einführung Datenbank in MySQL einrichten mit PhpMyAdmin PhpMyAdmin = grafsches Tool zur Verwaltung von MySQL-Datenbanken Datenbanken erzeugen und löschen Tabellen und Spalten einfügen,

Mehr

Unterabfragen (Subqueries)

Unterabfragen (Subqueries) Unterabfragen (Subqueries) Die kürzeste Formulierung ist folgende: SELECT Felderliste FROM Tabelle1 WHERE Tabelle1.Feldname Operator (SELECT Feldname FROM Tabelle2 WHERE Bedingung); wobei Tabelle1 und

Mehr

Konstante Relationen

Konstante Relationen Konstante Relationen values-syntax erzeugt konstante Relation values ( [, Konstante] * )[, ( [, Konstante] * )]* Beispiel values (1, eins ), (2, zwei ), (3, drei ); Resultat ist eine

Mehr

CARL HANSER VERLAG. Christopher Allen. Oracle PL/SQL für Einsteiger Der Einsatz von SQL und PL/SQL in der Oracle-Datenbank 3-446-21801-7

CARL HANSER VERLAG. Christopher Allen. Oracle PL/SQL für Einsteiger Der Einsatz von SQL und PL/SQL in der Oracle-Datenbank 3-446-21801-7 CARL HANSER VERLAG Christopher Allen Oracle PL/SQL für Einsteiger Der Einsatz von SQL und PL/SQL in der Oracle-Datenbank 3-446-21801-7 www.hanser.de Inhaltsverzeichnis Danksagung...XI Einleitung...XIII

Mehr

Einführung in SQL. 1. Grundlagen SQL. Structured Query Language. Viele Dialekte. Unterteilung: i. DDL (Data Definition Language)

Einführung in SQL. 1. Grundlagen SQL. Structured Query Language. Viele Dialekte. Unterteilung: i. DDL (Data Definition Language) Einführung in SQL 1. Grundlagen Structured Query Language Viele Dialekte Unterteilung: i. DDL (Data Definition Language) ii. iii. DML (Data Modifing Language) DRL (Data Retrival Language) 1/12 2. DDL Data

Mehr

Kapitel DB:VI (Fortsetzung)

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

Mehr

Übung Datenbanken in der Praxis. Datenmodifikation mit SQL

Übung Datenbanken in der Praxis. Datenmodifikation mit SQL Datenmodifikation mit SQL Folie 45 SQL - Datenmodifikation Einfügen INSERT INTO Relation [(Attribut, Attribut,...)] VALUES (Wert, Wert,...) INSERT INTO Relation [(Attribut, Attribut,...)] SFW-Anfrage Ändern

Mehr

Datenbanken: Datenintegrität. www.informatikzentrale.de

Datenbanken: Datenintegrität. www.informatikzentrale.de Datenbanken: Datenintegrität Definition "Datenkonsistenz" "in der Datenbankorganisation (...) die Korrektheit der gespeicherten Daten im Sinn einer widerspruchsfreien und vollständigen Abbildung der relevanten

Mehr

5. Datendefinition in SQL

5. Datendefinition in SQL Datendefinition 5. Datendefinition in SQL Schema, Datentypen, Domains Erzeugen von Tabellen (CREATE TABLE) Schemaevolution: Ändern/Löschen von Tabellen Sichtkonzept (Views) CREATE VIEW / DROP VIEW Problemfälle

Mehr

Form Designer. Leitfaden

Form Designer. Leitfaden Leitfaden Copyright Die hier enthaltenen Angaben und Daten können ohne vorherige Ankündigung geändert werden. Die in den Beispielen verwendeten Namen und Daten sind frei erfunden, soweit nichts anderes

Mehr

Transaktionen und Synchronisation konkurrierender Zugriffe

Transaktionen und Synchronisation konkurrierender Zugriffe Transaktionen und Synchronisation konkurrierender Zugriffe Fragestellungen Aufgaben des Transaktionsmanagers Aktivieren von Transaktionen entsprechend den Anforderungen von Anwendungsprogrammen. Dabei

Mehr

PostgreSQL im praktischen Einsatz. Stefan Schumacher

PostgreSQL im praktischen Einsatz. Stefan Schumacher PostgreSQL im praktischen Einsatz 2. Brandenburger Linux Infotag 2005 Stefan Schumacher , PGP Key http:/// $Header: /home/daten/cvs/postgresql/folien.tex,v 1.11 2005/04/25

Mehr

Oracle 12c: Neuerungen in PL/SQL. Roman Pyro DOAG 2014 Konferenz

Oracle 12c: Neuerungen in PL/SQL. Roman Pyro DOAG 2014 Konferenz Oracle 12c: Neuerungen in PL/SQL Roman Pyro DOAG 2014 Konferenz Herrmann & Lenz Services GmbH Herrmann & Lenz Solutions GmbH Erfolgreich seit 1996 am Markt Firmensitz: Burscheid (bei Leverkusen) Beratung,

Mehr

JDBC. Es kann z.b. eine ODBC-Treiberverbindung eingerichtet werden, damit das JAVA-Programm auf eine ACCESS-DB zugreifen kann.

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

Mehr

JOB SCHEDULER. Managed User Jobs. Dokumentation Juli 2005. MySQL-Job-Automation

JOB SCHEDULER. Managed User Jobs. Dokumentation Juli 2005. MySQL-Job-Automation MySQL-Job-Automation Managed User Jobs JOB SCHEDULER Dokumentation Juli 2005 Software- und Organisations-Service GmbH Giesebrechtstr. 15 D-10629 Berlin Telefon (030) 86 47 90-0 Telefax (030) 861 33 35

Mehr

8 Access-Abfragen migrieren

8 Access-Abfragen migrieren Leseprobe aus Access und SQL Server http://www.acciu.de/asqllesen 8 Access-Abfragen migrieren Mit der Migration der Tabellen Ihrer Anwendung zu einer SQL Server-Datenbank und dem Verknüpfen der SQL Server-Tabellen

Mehr

Datenbanken: Transaktionskonzept und Concurrency Control

Datenbanken: Transaktionskonzept und Concurrency Control Wesentlich für das Arbeiten mit Datenbanken sind konsistente Datenbestände! Folgerung: es muss sichergestellt werden, dass Datenmanipulationen von Benutzern immer in einem erneut konsistenten Zustand der

Mehr

Dokumentation zur Anlage eines JDBC Senders

Dokumentation zur Anlage eines JDBC Senders Dokumentation zur Anlage eines JDBC Senders Mithilfe des JDBC Senders ist es möglich auf eine Datenbank zuzugreifen und mit reiner Query Datensätze auszulesen. Diese können anschließend beispielsweise

Mehr

Dokumentation QuickHMI-Schnittstelle für Oracle Datenbanken

Dokumentation QuickHMI-Schnittstelle für Oracle Datenbanken Dokumentation QuickHMI-Schnittstelle für Oracle Datenbanken Version 2.0 D-28359 Bremen info@indi-systems.de Tel + 49 421-989703-30 Fax + 49 421-989703-39 Inhaltsverzeichnis Was ist die QuickHMI-Schnittstelle

Mehr

Tag 4 Inhaltsverzeichnis

Tag 4 Inhaltsverzeichnis Tag 4 Inhaltsverzeichnis Normalformen Problem Formen (1-4) Weitere Formen Transaktionen Synchronisationsprobleme Überblick Autocommit Locking Savepoints Isolation levels Übungen RDB 4-1 Normalformen Problematik

Mehr

XAMPP-Systeme. Teil 3: My SQL. PGP II/05 MySQL

XAMPP-Systeme. Teil 3: My SQL. PGP II/05 MySQL XAMPP-Systeme Teil 3: My SQL Daten Eine Wesenseigenschaft von Menschen ist es, Informationen, in welcher Form sie auch immer auftreten, zu ordnen, zu klassifizieren und in strukturierter Form abzulegen.

Mehr

Eine völlig andere Form Abfragen zu erstellen ist, sie mit Hilfe der Datenbankabfragesprache SQL zu gestalten.

Eine völlig andere Form Abfragen zu erstellen ist, sie mit Hilfe der Datenbankabfragesprache SQL zu gestalten. Einführung SQL 2010 Niko Becker Mit unseren Übungen zu ACCESS können Sie Aufbau und Struktur einer relationalen Datenbank kennenlernen. Wir zeigen Ihnen wie Sie Tabellen, Formulare und Berichte erstellen

Mehr

Labor 3 - Datenbank mit MySQL

Labor 3 - Datenbank mit MySQL Labor 3 - Datenbank mit MySQL Hinweis: Dieses Labor entstand z.t. aus Scripten von Prof. Dr. U. Bannier. 1. Starten des MySQL-Systems MySQL ist ein unter www.mysql.com kostenlos erhältliches Datenbankmanagementsystem.

Mehr

11 Funktionen. 11.1 Vorteile von Funktionen. Leseprobe aus Access und SQL Server http://www.acciu.de/asqllesen

11 Funktionen. 11.1 Vorteile von Funktionen. Leseprobe aus Access und SQL Server http://www.acciu.de/asqllesen Leseprobe aus Access und SQL Server http://www.acciu.de/asqllesen 11 Funktionen Bestimmt enthält Ihre Access-Applikation einige VBA-Funktionen. Funktionen, in denen Sie wie derkehrende Funktionalität,

Mehr

ISU 1. Ue_08/02_Datenbanken/SQL. 08 Datenbanken. Übung. SQL Einführung. Eckbert Jankowski. www.iit.tu-cottbus.de

ISU 1. Ue_08/02_Datenbanken/SQL. 08 Datenbanken. Übung. SQL Einführung. Eckbert Jankowski. www.iit.tu-cottbus.de 08 Datenbanken Übung SQL Einführung Eckbert Jankowski www.iit.tu-cottbus.de Datenmodell (Wiederholung, Zusammenfassung) Objekte und deren Eigenschaften definieren Beziehungen zwischen den Objekten erkennen/definieren

Mehr

Dipl. Inf. Eric Winter. PostgreSQLals HugeData Storage Ein Erfahrungsbericht

Dipl. Inf. Eric Winter. PostgreSQLals HugeData Storage Ein Erfahrungsbericht Dipl. Inf. Eric Winter Entwicklungsleiter PTC GPS-Services GmbH PostgreSQLals HugeData Storage Ein Erfahrungsbericht Inhalt 1. Problembeschreibung 2. Partielle Indexierung 3. Partitionierung 1. Vererbung

Mehr

Whitepaper. Produkt: combit Relationship Manager 6. Import von Adressen nach Firmen und Kontakte. combit GmbH Untere Laube 30 78462 Konstanz

Whitepaper. Produkt: combit Relationship Manager 6. Import von Adressen nach Firmen und Kontakte. combit GmbH Untere Laube 30 78462 Konstanz combit GmbH Untere Laube 30 78462 Konstanz Whitepaper Produkt: combit Relationship Manager 6 Import von Adressen nach Firmen und Kontakte Import von Adressen nach Firmen und Kontakte - 2 - Inhalt Ausgangssituation

Mehr

SQL-Befehlsliste. Vereinbarung über die Schreibweise

SQL-Befehlsliste. Vereinbarung über die Schreibweise Vereinbarung über die Schreibweise Schlüsselwort [optionale Elemente] Beschreibung Befehlsworte in SQL-Anweisungen werden in Großbuchstaben geschrieben mögliche, aber nicht zwingend erforderliche Teile

Mehr

View. Arbeiten mit den Sichten:

View. Arbeiten mit den Sichten: View "individuelle Sicht" (vgl. 3-Schichten-Modell) virtuelle Tabellen: in der DB wird nicht deren Inhalt, sondern nur die Ableitungsregel gespeichert. Arbeiten mit den Sichten: Anfragen: kein Problem.

Mehr

Automatisierte Datenmigration mit dynamischen SQL

Automatisierte Datenmigration mit dynamischen SQL Automatisierte Datenmigration mit dynamischen SQL Rolf Wesp Consultant Rolf.Wesp@trivadis.com Düsseldorf, 27. Oktober 2009 Baden Basel Bern Brugg Lausanne Zürich Düsseldorf Frankfurt/M. Freiburg i. Br.

Mehr

SQL: statische Integrität

SQL: statische Integrität SQL: statische Integrität.1 SQL: statische Integrität Im allgemeinen sind nur solche Instanzen einer Datenbank erlaubt, deren Relationen die der Datenbank bekannten Integritätsbedingungen erfüllen. Integritätsbedingungen

Mehr

Kurs. Teil 7 UNDO-Management. Universität Hannover. Agenda. Einführung. Nutzung RBS Oracle 9i Einführung Performance Tuning.

Kurs. Teil 7 UNDO-Management. Universität Hannover. Agenda. Einführung. Nutzung RBS Oracle 9i Einführung Performance Tuning. Kurs Oracle 9i Performance Tuning Teil 7 UNDO-Management Timo Meyer Wintersemester 2005 / 2006 Seite 1 von 23 Seite 1 von 23 1. 2. Nutzung des Rollback Segments 3. 4. 5. Größe von UNDO- TBS berechnen 6.

Mehr

Java Application 1 Java Application 2. JDBC DriverManager. JDBC-ODBC Br idge. ODBC Driver Manager. Dr iver C. Dr iver D.

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

Mehr

SQL und MySQL. Kristian Köhntopp

SQL und MySQL. Kristian Köhntopp SQL und MySQL Kristian Köhntopp Wieso SQL? Datenbanken seit den frühen 1950er Jahren: Hierarchische Datenbanken Netzwerkdatenbanken Relationale Datenbanken = SQL Relational? 10 9 8 7 6 f(y) := y = x r(y)

Mehr

www.informatik-aktuell.de

www.informatik-aktuell.de www.informatik-aktuell.de Luxaviation Germany GmbH Wer bin ich? Marek Adar/ Bj. 1970 / 4 Kinder 2, 5, 15, 20 Luxaviation Group / IT-Leitung Luxaviation Germany Gruppenweit zuständig für Oracle, Monitoring,

Mehr

Whitepaper Externe Speicherung von Binary Large Objects (BLOBs) mit SharePoint 2007 sowie SQL Server 2005 / 2008

Whitepaper Externe Speicherung von Binary Large Objects (BLOBs) mit SharePoint 2007 sowie SQL Server 2005 / 2008 Externe Speicherung von Binary Large Objects (BLOBs) mit SharePoint 2007 sowie SQL Andreas Glaser, 23. September 2008 Teufenerstrasse 19 CH 9001 St.Gallen t [+41] 71 228 67 77 f [+41] 71 228 67 88 info@namics.com

Mehr

Verteilte Datenbanken. Folien zum Datenbankpraktikum Wintersemester 2009/10 LMU München

Verteilte Datenbanken. Folien zum Datenbankpraktikum Wintersemester 2009/10 LMU München Kapitel 8 Verteilte Datenbanken Folien zum Datenbankpraktikum Wintersemester 2009/10 LMU München 2008 Thomas Bernecker, Tobias Emrich unter Verwendung der Folien des Datenbankpraktikums aus dem Wintersemester

Mehr

Dieser Foliensatz darf frei verwendet werden unter der Bedingung, dass diese Titelfolie nicht entfernt wird.

Dieser Foliensatz darf frei verwendet werden unter der Bedingung, dass diese Titelfolie nicht entfernt wird. Thomas Studer Relationale Datenbanken: Von den theoretischen Grundlagen zu Anwendungen mit PostgreSQL Springer, 2016 ISBN 978-3-662-46570-7 Dieser Foliensatz darf frei verwendet werden unter der Bedingung,

Mehr

Oracle: Abstrakte Datentypen:

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

Mehr

6. Datenintegrität. Integritätsbedingungen

6. Datenintegrität. Integritätsbedingungen 6. Integritätsbedingungen dienen zur Einschränkung der Datenbankzustände auf diejenigen, die es in der realen Welt tatsächlich gibt. sind aus dem erstellten Datenmodell ableitbar (semantisch) und können

Mehr