Java sql

berserkerdq2

Bekanntes Mitglied
Hi, wenn man in Java Tabellen für eine Datenbank erstellen kann.

Dann hat man das ja in einem try catch block und dann ein Satement wie z. B.:

if table not exists ...

Was ich nicht kapiere, man kann ja das statement closen, gleichzeitig kann ich ja auch die connection commiten, aber wann ist das verpflichtend und wann nicht?

Bsp.:

Java:
        try(Statement op= c.createStatement()) {
            String sqlst = "CREATE tABLE IF NOT EXISTS Studiengaenge"+
                    "(ID INTEGER PRIMARY KEY,"+
                    "Name TEXT NOT NULL,")
            op.executeUpdate(sqlst); //1.muss ich das jetzt machen?
            //2.Muss ich vllt auch c.commit() machen?
            op.close(); //3.Ist das close hier nötig?
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
 
Beste Antwort
COMMIT dient zum Abschluss einer Transaktion. Das ist völliger Käse:
das commit ist dafür da dass du deiner DB nicht mit jeder kleinigkeit auf den sack gehst
Das Gegenstück zu COMMIT ist ROLLBACK. Ich mach es mal stark vereinfacht: Du machst 1 Insert + ein Update auf einen anderen DS. Jetzt kommt es zu einem Fehler, weil dein Update nicht i.O. ist. Wenn du jetzt den Ursprungszustand zurückhaben möchtest, also vor dem Insert, dann hast du ein Problem, wenn du zwischenzeitlich ein Commit gemacht hast. Hast du das aber nicht kannst du in deinem Exception-Handler Rollback aufrufen - und schon hast du den Zustand vor allen Aktionen nach dem letzten Commit.
Es gibt da noch viel mehr Möglichkeiten, mit Savepoints und Transaktionen über...

Oneixee5

Top Contributor
Prinzipiell muss jede JDBC-Resource mit close() geschlossen werden. Dabei schließen übergeordnete Ressourcen die untergeordneten. Wenn man also die Connection schließt sind auch mögliche Statements und ResultSets geschlossen. Man sollte so aber nicht vorgehen und die Systemressourcen schonen. Wenn man JDBC-Resource in einem try-with-resources-Block verwendet, muss die close()-Methode nicht explizit aufgerufen werden, da der try-with-resources-Block dies (auch im Fehlerfall) automatisch erledigt.
 

berserkerdq2

Bekanntes Mitglied
Prinzipiell muss jede JDBC-Resource mit close() geschlossen werden. Dabei schließen übergeordnete Ressourcen die untergeordneten. Wenn man also die Connection schließt sind auch mögliche Statements und ResultSets geschlossen. Man sollte so aber nicht vorgehen und die Systemressourcen schonen. Wenn man JDBC-Resource in einem try-with-resources-Block verwendet, muss die close()-Methode nicht explizit aufgerufen werden, da der try-with-resources-Block dies (auch im Fehlerfall) automatisch erledigt.
Okay und commit? Ist das immer nötig? Wenn ich keinen autocommit befehl aktiv habe, ist dann autocommit automatisch false? Und muss ich bei einem fremdschlüssel eigentlich extra screiben,d ass er ein fremdschlüssel ist oder reicht es wenn ich refernces mache? Ist das dann automatisch ein fremdschlüssel, wenn ich über references einen primarykey referenziere?
 
Y

yfons123

Gast
das commit ist dafür da dass du deiner DB nicht mit jeder kleinigkeit auf den sack gehst

du schickst paar sql befehle hin und die db rattert alle durch... die fängt doch nicht bei jedem befehl neu an
 

Oneixee5

Top Contributor
Die Groß-/Kleinschreibung ist normalerweise egal. Aufpassen muss man mit den darunterliegenden Dateisystemen. Durch bestimmte Einstellungen bei MySQL kann es unter Linux sein, dass man Tabellen/Spalten immer so schreiben muss, wie diese angelegt wurden.
 

Oneixee5

Top Contributor
COMMIT dient zum Abschluss einer Transaktion. Das ist völliger Käse:
das commit ist dafür da dass du deiner DB nicht mit jeder kleinigkeit auf den sack gehst
Das Gegenstück zu COMMIT ist ROLLBACK. Ich mach es mal stark vereinfacht: Du machst 1 Insert + ein Update auf einen anderen DS. Jetzt kommt es zu einem Fehler, weil dein Update nicht i.O. ist. Wenn du jetzt den Ursprungszustand zurückhaben möchtest, also vor dem Insert, dann hast du ein Problem, wenn du zwischenzeitlich ein Commit gemacht hast. Hast du das aber nicht kannst du in deinem Exception-Handler Rollback aufrufen - und schon hast du den Zustand vor allen Aktionen nach dem letzten Commit.
Es gibt da noch viel mehr Möglichkeiten, mit Savepoints und Transaktionen über mehrere DB's usw.
 
Beste Antwort

berserkerdq2

Bekanntes Mitglied
COMMIT dient zum Abschluss einer Transaktion. Das ist völliger Käse:

Das Gegenstück zu COMMIT ist ROLLBACK. Ich mach es mal stark vereinfacht: Du machst 1 Insert + ein Update auf einen anderen DS. Jetzt kommt es zu einem Fehler, weil dein Update nicht i.O. ist. Wenn du jetzt den Ursprungszustand zurückhaben möchtest, also vor dem Insert, dann hast du ein Problem, wenn du zwischenzeitlich ein Commit gemacht hast. Hast du das aber nicht kannst du in deinem Exception-Handler Rollback aufrufen - und schon hast du den Zustand vor allen Aktionen nach dem letzten Commit.
Es gibt da noch viel mehr Möglichkeiten, mit Savepoints und Transaktionen über mehrere DB's usw.
Aber warum soll man dann commit statt autocommit nutzen, wie manche in Foren empfohlen haben?
 

mihe7

Top Contributor
Also mache ich das warum? Also warum sollte ich commit machen?
Die große Stärke von RDBMS sind die ACID-Eigenschaften von Transaktionen:
  1. Atomarität: das alles oder nichts Prinzip - entweder geht eine Transaktion vollständig durch oder gar nicht.
  2. Konsistenz: nach einer Transaktion befindet sich die Datenbank in einem konsistenten Zustand
  3. Isolation: Transaktion laufen unabhängig voneinander, beeinflussen sich also nicht.
  4. Dauerhaftigkeit: Wenn eine Transaktion erfolgreich abgeschlossen wurde, sind die Änderungen dauerhaft gespeichert.
Eine Transaktion ist dabei einfach eine Folge von Anweisungen, die als eine Einheit betrachtet werden.

So ein Transaktionsmanager hat einen Haufen Arbeit, die mit einigem Aufwand verbunden ist. Die Forderung nach Dauerhaftigkeit macht es z. B. notwendig, möglichst unter Umgehung etwaiger Schreibcaches auf den Datenträger zu schreiben aber da hängt noch einiges mehr dran. So muss die Datenbank nach dem Start in einem konsistenten Zustand sein, auch wenn mitten in einer Transaktion der Strom ausgefallen ist. Hinzu kommen weitere Dinge, die die DB durchsetzen muss wie z. B. Sicherheitsregeln.

Warum solltest Du also nicht jeden Befehl in eine eigene Transaktion stecken? Vom konzeptionellen Standpunkt aus betrachtet, wirst Du Situationen haben, die eben nicht mit einem Befehl an die DB erschlagen werden können. Denken wir z. B. an die doppelte Buchführung, wo mit einer Buchung (=Transaktion) mindestens zwei Konten belastet werden. Wenn Du jede Buchung in einer Transaktion steckst, kann es Dir passieren, dass die Buchhaltung falsch wird.

Ein anderer Punkt, der oben bereits angeschnitten wurde: Transaktionen sind teuer. Wenn Du z. B. viele einzelne Sätze in die DB einfügst und nach jedem Satz eine neue Transaktion beginnst, dauert das. In dem Fall kann man neben Bulk-Operationen auch größere Transaktionen durchführen, einfach um die Geschwindigkeit zu erhöhen. Das muss man ggf. messen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
OnDemand Java Deployment Vaadin Allgemeine Java-Themen 3
D Hat Java eine Library um JavaScript auszuwerten? Allgemeine Java-Themen 2
Zrebna Wieso sind eigentlich JUnit-Tests in src/test/java platziert - nur Konvention? Allgemeine Java-Themen 7
N LlaMA, KI, java-llama.cpp Allgemeine Java-Themen 39
V Java-Codierungsherausforderung: Navigieren durch die Macken der Datumsmanipulation Allgemeine Java-Themen 2
E Output Fehler (Java-Programm Kuchen) Allgemeine Java-Themen 11
M java: unexpected type Allgemeine Java-Themen 2
harrytut Java Input/Output Tests Junit Allgemeine Java-Themen 3
B Java Discord bot auf ein Root Server? Allgemeine Java-Themen 1
BetziTheRealOne Java PKIX path building failed as non Admin Allgemeine Java-Themen 15
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
KonradN Java 21 Release Allgemeine Java-Themen 5
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
K Java Anwendung machen Anleitung Allgemeine Java-Themen 5
G java.io.listFiles() Allgemeine Java-Themen 3
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
K Java-Projekt Allgemeine Java-Themen 11
K Java-Projekt Allgemeine Java-Themen 0
ruutaiokwu Welcher Browser unterstützt heutzutage noch Java Applets? Allgemeine Java-Themen 5
Jose05 Java-Klasse im extra cmd-Fenster ausführen Allgemeine Java-Themen 3
rode45e Java Threads Allgemeine Java-Themen 4
G java.io.listFiles() Allgemeine Java-Themen 2
N Java Dynamic Proxy Allgemeine Java-Themen 3
N Leichte Java Gegner Ki Allgemeine Java-Themen 10
A Java modul Problem Allgemeine Java-Themen 4
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
V Funktionale Schnittstelle in Java Allgemeine Java-Themen 3
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
berserkerdq2 Wenn ich bei Intelij javafx mit maven importieren will, muss ich das in die pom.xml reintun, aber warum noch in module-info.java? Allgemeine Java-Themen 3
KonradN Java 20 am 21. März Allgemeine Java-Themen 1
O Java Website Stock Bot Allgemeine Java-Themen 3
J Front-/Backend in Java Allgemeine Java-Themen 14
doopexxx JAVA Google Webcrawler Allgemeine Java-Themen 1
J JavaScript innerhalb eines Java Projekts ausführen Allgemeine Java-Themen 2
A Java Programm erstellen hilfe Allgemeine Java-Themen 10
G java.lang.NoClassDefFoundError: org/aspectj/lang/Signature Allgemeine Java-Themen 2
lalex1491 Java Aktienkurse nachfragen Allgemeine Java-Themen 4
J Class to link Java Allgemeine Java-Themen 4
V Wie funktioniert das Schlüsselwort "final" von Java? Allgemeine Java-Themen 19
mrStudent Inferenz JAVA Allgemeine Java-Themen 6
U URI Rechner (Java Script) Allgemeine Java-Themen 7
TheSkyRider Java Geburtsdatum Textfeld Allgemeine Java-Themen 7
mihe7 Java 19 JavaDocs: Browserintegration Allgemeine Java-Themen 0
Encera Gleichzeitiges Ausführen und verbinden von 2 Java-Klassen über die Eingabeaufforderung und Eclipse Allgemeine Java-Themen 21
H Java Rechner Programmierung der Mathematik Allgemeine Java-Themen 33
Lennox Schinkel Java Kara Auf einen Java Host laufen lassen Allgemeine Java-Themen 17
C Fußnoten von DocX mit Java Allgemeine Java-Themen 2
C Fußnoten in DocX mit Java Allgemeine Java-Themen 1
M Aussagenlogik in Java Programmieren Allgemeine Java-Themen 22
B Per Java Word Dokument schreiben? Allgemeine Java-Themen 8
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
KonradN Oracle übergibt (Java Teile der) GraalVM Community Edition an OpenJDK Community Allgemeine Java-Themen 2
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
B Java mit command line und jars benutzen? Allgemeine Java-Themen 18
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
B HTTP Allgemeine Fragen über Suchmaschine nutzen mit Java Allgemeine Java-Themen 20
Mick P. F. Wie kriege ich die Fehlermeldung "java: symbol lookup error: ..." weg? Allgemeine Java-Themen 11
K Nachhilfe Java Allgemeine Java-Themen 11
KonradN Java 19 Allgemeine Java-Themen 11
F IDEA IntelliJ Java Songliste erstellen Allgemeine Java-Themen 6
TheSepp Java bestimmtes Array auf den Wert 0 setzen Allgemeine Java-Themen 32
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
Sachinbhatt Sind alle Methoden in Java implizit virtuell Allgemeine Java-Themen 2
E Java und integrierte Grafikkarten Allgemeine Java-Themen 18
Sachinbhatt Wie wird die Typumwandlung bei Mehrfachvererbung in Java implementiert? Allgemeine Java-Themen 3
Peterw73 Hilfe bei Java gesucht Allgemeine Java-Themen 3
A Java unter Win 10 Allgemeine Java-Themen 1
B Woher kommen die Bildschirmkoordinaten beim java Robot? Allgemeine Java-Themen 14
P9cman java.Lang Klassen fehlen in JRE System Library Allgemeine Java-Themen 1
T Java Robot Class - Bot Allgemeine Java-Themen 3
E Wie Java Heap Space vergrößern? Allgemeine Java-Themen 3
B Java Programm auf virutellem Desktop laufen lassen? Allgemeine Java-Themen 1
D VBA Code mit Java ausführen möglich? Allgemeine Java-Themen 10
berserkerdq2 Threads, wie genau läuft das in Java ab? (Ich kann Threads erstellen und nutzen, nur das Verständnis) Allgemeine Java-Themen 6
izoards Java Home Pfad unabhängig von der Version Allgemeine Java-Themen 7
N JAVA-Code mit Grafikfenster zeichnet in Windows, aber nicht Mac. Allgemeine Java-Themen 4
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
KonradN CVE-2022-21449: Fehler in Java bei Signaturprüfung Allgemeine Java-Themen 20
JordenJost Unverständlicher Java code? Allgemeine Java-Themen 21
LimDul XSD To Java - Überschreiben von Assoziationen Allgemeine Java-Themen 1
Aartiyadav Comparisons and Swapa in Bubble-sort Java Allgemeine Java-Themen 6
KonradN Java 18 Allgemeine Java-Themen 8
N Statistische Auswertung von Logfiles (Einlesen, auswerten und grafische Aufbereitung von logfiles) mit Java Allgemeine Java-Themen 9
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
Z Mit Java 8+ Streams Zeilen nummern zu Zeilen hinzufügen Allgemeine Java-Themen 17
M Verständnisfrage java.util.TimerTask Allgemeine Java-Themen 2
V Hilfe mit Java Code Allgemeine Java-Themen 4
S Processing Java Code verstehen Allgemeine Java-Themen 4
O Newton Algorithmus Java Allgemeine Java-Themen 1
P Java Quellen finden Allgemeine Java-Themen 3
M Java Analyse/ SWOT-Analyse Allgemeine Java-Themen 13
J c Programm läuft nicht in compilierter Version des Java Projektes Allgemeine Java-Themen 7
Atten007 Java-Klasse auf macOS entpacken? Allgemeine Java-Themen 2
E java mithilfe url .jar datei öffnen Allgemeine Java-Themen 9
M Warum hat Java dieses und jenes nicht... Allgemeine Java-Themen 8
E Java .exe Datei mit args starten Allgemeine Java-Themen 2
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18

Ähnliche Java Themen

Neue Themen


Oben